?php/** * User: wanwan * Date: 16/2/28 * Time: 下午4:39 * email:18618300482@163.com */ date_default_timezone_set('Asia/Shanghai'); /** * 写日志 * @param $msg */function make_log($msg){ $dir = __DIR__ . '/checksLog'; if (is_dir($dir)) {
<?php
/**
* User: wanwan
* Date: 16/2/28
* Time: 下午4:39
* email:18618300482@163.com
*/
date_default_timezone_set('Asia/Shanghai');
/**
* 写日志
* @param $msg
*/
function make_log($msg)
{
$dir = __DIR__ . '/checksLog';
if (is_dir($dir)) {
file_put_contents($dir . '/' . date('Y-m-d') . '.log', date("y-m-d H:i:s") . $msg . "\\n", FILE_APPEND);
} else {
mkdir($dir);
file_put_contents($dir . '/' . date('Y-m-d') . '.log', date("y-m-d H:i:s") . $msg . "\\n", FILE_APPEND);
}
}
/**
* 检查进程是否存在
* @param $clsname
* @param int $bf
* @return int
*/
function isRun($clsname, $bf = 0)
{
//下面进行检测,如有一个进程正在运行,则不运行
$str = shell_exec("ps ax > " .__DIR__ .'/'.$clsname . "_run.txt");
$str = shell_exec("grep -c '" .$clsname . "' " . __DIR__.'/'. $clsname . "_run.txt");
if ($bf > 0) {
if ($str >= $bf) {
return 1;
} else {
return 0;
}
} else {
if ($str >= 2) {
return 1;
} else {
return 0;
}
}
}
define('QUEUE', 'RedisQueueServer');
define('HTTP', 'httpd');
define('NG', 'nginx');
define('REDIS', 'redis-server');
define('SQL', 'mysql');
//检查队列进程
if (isRun(QUEUE)) {
make_log('RedisQueueServer is running !');
} else {
make_log('RedisQueueServer is not running ! try to start it....');
exec('php /WanQueue/console/RedisQueueServer.php');
if (isRun(QUEUE)) {
make_log('RedisQueueServer start success !');
} else {
make_log('RedisQueueServer start failed !');
sendEmail('12312313,12312313', '[APPNAME-ServerError]:服务器的队列进程RedisQueueServer挂了,自动重启失败!!');
}
}
//检查sql进程
if (isRun(SQL)) {
make_log('mysql is running !');
} else {
make_log('mysql is not running ! try to start it....');
exec('service mysql start');
if (isRun(SQL)) {
make_log('mysql start success !');
} else {
make_log('mysql start failed !');
sendEmail('12312313,12312313', '[APPNAME-ServerError]:服务器的队列进程mysql挂了,自动重启失败!!');
}
}
//检查httpd进程
if (isRun(HTTP)) {
make_log('httpd is running !');
} else {
make_log('httpd is not running ! try to start it....');
exec('httpd -k start');
if (isRun(HTTP)) {
make_log('httpd start success !');
} else {
make_log('httpd start failed !');
sendEmail('12312313,12312313', '[APPNAME-ServerError]:服务器的队列进程httpd挂了,自动重启失败!!');
}
}
//检查nginx进程
if (isRun(NG)) {
make_log('nginx is running !');
} else {
make_log('nginx is not running ! try to start it....');
exec('nginx');
if (isRun(NG)) {
make_log('nginx start success !');
} else {
make_log('nginx start failed !');
sendEmail('12312313,12312313', '[APPNAME-ServerError]:服务器的队列进程nginx挂了,自动重启失败!!');
}
}
//检查redis进程
if (isRun(REDIS)) {
make_log('redis is running !');
} else {
make_log('redis is not running ! try to start it....');
exec('nohup redis-server &');
if (isRun(REDIS)) {
make_log('redis start success !');
} else {
make_log('redis start failed !');
sendEmail('12312313,12312313', '[APPNAME-ServerError]:服务器的队列进程redis-server挂了,自动重启失败!');
}
}
