Heim >Backend-Entwicklung >PHP-Tutorial >Über PHP-Multiprozessprogrammierung (detaillierte Code-Erklärung)
PHP-Multiprozessprogrammierung
PHPs Prozesssteuerungsunterstützung implementiert die Prozesserstellung und Programmausführung im Unix-Stil, Signal Handhabung und Prozessunterbrechung. Die Prozesssteuerung kann nicht in einer Webserverumgebung verwendet werden und kann bei Verwendung in einer Webdienstumgebung zu unerwarteten Ergebnissen führen.
pcntl-Funktion
pcntl_fork(): Erzeugt einen Zweig (untergeordneten Prozess) an der aktuellen Position des aktuellen Prozesses.
Anmerkung: Fork erstellt einen untergeordneten Prozess. Der Unterschied besteht darin, dass der Fork-Rückgabewert während der Ausführung des übergeordneten Prozesses der untergeordnete Prozess ist Zahl. Was der untergeordnete Prozess erhält, ist 0
<?php $pid = pcntl_fork(); //父进程和子进程都会执行下面代码 if ($pid == -1) { //错误处理:创建子进程失败时返回-1. die('could not fork'); } else if ($pid) { //父进程会得到子进程号,所以这里是父进程执行的逻辑 pcntl_wait($status); //等待子进程中断,防止子进程成为僵尸进程。 } else { //子进程得到的$pid为0, 所以这里是子进程执行的逻辑。 exit();//子进程执行完后应该退出,不然会继续执行后面的逻辑 }
● pcntl_wait(int &$status[, int $options = 0]): Warten Sie auf den untergeordneten Prozessstatus von fork oder geben Sie ihn zurück, entspricht pcntl_waitpid(-1 ,int &$ status[,int $options = 0])
● pcntl_waitpid(int $pid, int &$status[,int $options = 0]) $status ist ein Parameter der folgenden Funktion
● pcntl_wifexited(int $status) prüft, ob der Statuscode des untergeordneten Prozesses einen normalen Exit darstellt.
● pcntl_wexistatus(int $status) gibt einen Rückkehrcode für einen unterbrochenen untergeordneten Prozess zurück, der nur für eine normale Unterbrechung gültig ist
● pcntl_wifsignaled(int $status) prüft, ob der untergeordnete Prozess durch ein nicht abgefangenes Signal beendet wurde. Gibt true zurück, wenn ja, false, wenn nicht
● pcntl_wtermsig(int $status) gibt das Signal zurück, das die Unterbrechung des untergeordneten Prozesses verursacht hat. Es ist gültig, wenn pcntl_wifsignaled true zurückgibt
<?php echo "主进程\n"; $pid = pcntl_fork(); //父进程和子进程都会执行这些代码 if($pid == -1 ){ //创建子进程失败会返回-1 throw new Exception ('fork error on Task object'); }else if($pid){ //创建成功会父进程会得到子进程的pid echo "等待子进程执行"; pcntl_wait($status);//等待子进程中断 echo "子进程执行状态:"; echo "是否正常退出:",pcntl_wifexited($status),"\n"; echo "子进程返回的代码:",pcntl_wexitstatus($status),"\n";//仅在pcntl_wifexited返回true时生效,只能是int,输出123 echo "子进程是否是由于某个未捕获的信号退出的:",pcntl_wifsignaled($status),"\n";//如果是kill -9|-15 杀死的进程返回true echo "导致子进程中断的信号:",pcntl_wtermsig($status),"\n"; 输出 9 | 15 var_dump($status); }else{ //创建成功子进程会得到pid=0 sleep(2); echo "子进程执行完毕\n"; exit(123) }
● pcntl_alarm( int $seconds): ist Der Prozess setzt ein Alarmsignal
● pcntl_signal(int $signo, callback $handler [, bool $restart_syscalls = true ]) Installiert einen neuen Signalhandler für das angegebene Signal
● pcntl_signal_get_handler (int $signo) Ruft die Verarbeitungsfunktion des angegebenen Signals ab
<?php echo "设置3秒之后发送闹钟信号\n"; pcntl_alarm(3); function dealSigalarm(){ echo "收到信号 SIGALRM \n退出程序。。。\n"; exit(); } echo "安装信号处理器\n"; pcntl_signal(SIGALRM,"dealSigalarm");//对于不能被阻塞、处理和忽略的信号,php为这些时间注册信号处理函数会产生一个致命错误SIGSTOP,SIGKILL var_dump(pcntl_signal_get_handler(SIGUSR1));//输出dealSigalarm pcntl_signal(SIGUSR1,function(){ echo "收到用户自定义信号\n"; }); $i = 1; while(1){ sleep(1); echo $i++,"\n"; echo "分发... \n"; pcntl_signal_dispatch(); };
● pcntl_getpriority( int $pid = getmypid() [, int $process_identifier = PRIO_PROCESS ]) Ruft die Priorität des Prozesses ab
● pcntl_setpriority (int $priority [, int $pid = getmypid() [, int $process_identifier = PRIO_PROCESS]]) Legen Sie die Priorität des Prozesses fest
● getmypid() Holen Sie sich die PID des aktuellen PHP-Prozesses
● posix_getpid() ruft die PID des aktuellen Prozesses ab
<?php /** * php进程的优先级 */ for($i = 1;$i<=5;$i++){ $pid = pcntl_fork(); if($pid == -1){ throw new Exception("fork error on task object"); }else if ($pid){ pcntl_wait($status); }else{ $end_time = time()+3; $k = 0; while(time()<=$end_time){ $k++; } $pid = getmypid(); echo "当前进程id:".$pid,"优先级:",pcntl_getpriority($pid); pcntl_setpriority($i); echo "修改之后的优先级为:",pcntl_getpriority(),"\n"; echo "执行了进程{$i} {$k}次\r\n"; exit(); } }
Weitere PHP-bezogene Kenntnisse finden Sie im PHP-Tutorial!
Das obige ist der detaillierte Inhalt vonÜber PHP-Multiprozessprogrammierung (detaillierte Code-Erklärung). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!