Process daemon written in PHP, process management, process error automatic startup function, suitable for server administrators_PHP tutorial

WBOY
Release: 2016-07-14 10:10:19
Original
1241 people have browsed it

Just install the php command line tool

Run the example:

php supervisor.php /usr/local/nginx/bin/nginx nobody (you can also add the parameters of the corresponding command after this, just leave it blank if there are no parameters) &


Parameter introduction: The first is the php executable program on the command line, the second is the code file below this article, the third is the executable program path that needs to be started, the fourth is what role to use to start it, and the following are reserved parameters, all passed to this executable program.

Advantages:

1. Programs that need to be daemonized run in a non-daemon state and can be restarted immediately when an error occurs

2. When the program is running as a daemon, it will check the running status regularly and restart within 1 second

3. You can set the number of restarts within a specific period of time. If the number exceeds the configured number, it will no longer restart, preventing the application from being unable to restart due to special circumstances.


Suggestion:

It is recommended to adjust the program to run in non-daemon state.


Copy the following code and save it as supervisor.php file


[php]
//author email: tipboy@qq.com
$_retry_times=5;
$_retry_times_duration=60; //This is how many times it has been restarted, and there is no need to restart again
$_times_arr=array();
$args=$_SERVER['argv'];
if(count($args)<3)
{
​ write_log("args num error!");
​ write_log("etc: php supervisor.php /usr/local/nginx/bin/nginx nobody xxx");
write_log("The first parameter is this file, the second parameter is the path of the executable file to be monitored, the third parameter is which user to use for execution, and the next parameter is the parameter used to execute the executable file");
exit();
}
//$args[0] is the name of this file
$path=$args[1];
$username=$args[2];
for($i=3;$i>0;$i--)
Array_shift($args);

while(1){
$pid=pcntl_fork();
If($pid==0)
{
//write_log("child ".getmypid()." run");
​​​ pcntl_exec($path,$args,$_SERVER);
           write_log("execute file failed");                    exit(0);
}  
else if($pid>0)
{
//write_log(" main pid:".getmypid().", child_pid:".$pid);
          $endpid=pcntl_waitpid($pid,$status,2);                                                                     //write_log("status:".$status);                                                                                  If($status==0) ​​
                                                                  ​​​​​​ //It may be a daemon program, running in the background
If(file_exists("/proc/".($pid+1)."/stat"))
                                                                  //Indicates that the process exists and needs to be judged regularly
                    write_log("program start success");                                                                                                        for (;;)
                                                                         If(file_exists("/proc/".($pid+1)."/stat"))
                                                                                                                                                                                                                                                                                                                                                         //write_log("program is alive"); usleep(1000000);
                                                                                                                                                                                                                       else                                                                                                                                    write_log("program die");                                break;
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   else                                                                                            //Indicates that the process does not exist and is not in a non-daemon state.
                    write_log("program start failed");                          exit(0);
                                                                                                                                               } 
         else if($status>0)
                                                                                             //Indicates that it is not a daemon program, it has exited and needs to be restarted
              write_log("program die");                                             //continue;                                         } 
            else  
                                                                    exit(0);
         } 

If(chk_need_start($_times_arr,$_retry_times_duration,$_retry_times))
                                                                    Continue;
         } 
            else  
                                                                    break;
         } 
}  
};


function write_log($msg)
{
Print(date('Y-m-d H:i:s').' '.$msg."n");
}

function chk_need_start(&$_times_arr,$_retry_times_duration,$_retry_times)
{ 
foreach($_times_arr as $k=>$v)
{
//write_log("duration:".$_retry_times_duration);
If($k                                                                     //write_log("do unset");
              unset($_times_arr[$k]);
                                                                    }  
//write_log("buffer count:".count($_times_arr));
If(count($_times_arr)>=$_retry_times)
{

        return false;
}  
else
{
          $_times_arr[time()]=1;
                                                                return true;
}  
}
?>

//author email: tipboy@qq.com
$_retry_times=5;
$_retry_times_duration=60; //This is how many times it has been restarted, and there is no need to restart again
$_times_arr=array();
$args=$_SERVER['argv'];
if(count($args)<3)
{
write_log("args num error!");
write_log("etc: php supervisor.php /usr/local/nginx/bin/nginx nobody xxx");
write_log("The first parameter is this file, the second parameter is the path of the executable file to be monitored, the third parameter is which user to use for execution, and the next parameter is the parameter used to execute the executable file");
exit();
}
//$args[0] is the name of this file

$path=$args[1];

$username=$args[2];
for($i=3;$i>0;$i--)
array_shift($args);

while(1){
$pid=pcntl_fork();
if($pid==0)
{
//write_log("child ".getmypid()." run");
pcntl_exec($path,$args,$_SERVER);
write_log("execute file failed");
exit(0);
}
else if($pid>0)
{
//write_log(" main pid:".getmypid().", child_pid:".$pid);
$endpid=pcntl_waitpid($pid,$status,2);
//write_log("status:".$status);
if($status==0)
{
//Indicates that it may be a daemon program, running in the background
if(file_exists("/proc/".($pid+1)."/stat"))
{
//Indicates that the process exists and needs to be judged regularly
​​write_log("program start success");
 
for (;;)
{
If(file_exists("/proc/".($pid+1)."/stat"))
{
​​​ //write_log("program is alive");
usleep(1000000);
}
      else
{
        write_log("program die");
        break;
}
}
       
}
else
{
//Indicates that the process does not exist and is not in a non-daemon state.
​​write_log("program start failed");
exit(0);
}
}
else if($status>0)
{
//Explain whether it is a non-daemon program. It has exited and needs to be restarted
Write_log("program die");
//continue;
}
else
{
exit(0);
}

if(chk_need_start($_times_arr,$_retry_times_duration,$_retry_times))
{
Continue;
}
else
{
Break;
}
}
};


function write_log($msg)
{
print(date('Y-m-d H:i:s').' '.$msg."n");
}

function chk_need_start(&$_times_arr,$_retry_times_duration,$_retry_times)
{
foreach($_times_arr as $k=>$v)
{
//write_log("duration:".$_retry_times_duration);
if($k {
//write_log("do unset");
Unset($_times_arr[$k]);
}
}
//write_log("buffer count:".count($_times_arr));
if(count($_times_arr)>=$_retry_times)
{

return false;
}
else
{
$_times_arr[time()]=1;

return true;
}
}
?>


www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/477518.htmlTechArticleAs long as the php command line tool is installed, you can run the example: php supervisor.php /usr/local/nginx/bin/ nginx nobody (you can also add the parameters of the corresponding command after this, just leave it blank if there are no parameters)...
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!