php 多进程中的信号有关问题

WBOY
Libérer: 2016-06-13 12:38:50
original
806 Les gens l'ont consulté

php 多进程中的信号问题

1.以下代码sleep时间远小于20

<?php // 当子进程退出时,会触发该函数
function sig_handler($sig) {
	switch($sig) {
		case SIGCHLD:
			echo 'SIGCHLD received'."n";
	}
}
  
pcntl_signal(SIGCHLD, "sig_handler");// 注册子进程退出时调用的函数

$start          = time(); 

$sub_process_cnt = 20;
for($i=0;$i<$sub_process_cnt;$i++) { 
  
	sleep(1);   
	 
	$pid  = pcntl_fork(); 
	if ($pid == 0) {

		exit(-1);
	}
}


$status = 0;
 
for ($k=0; $k<$sub_process_cnt; $k++) 
{
	pcntl_waitpid(-1, $status );
}


$end            = time();
$usage          = $end - $start;
print "End, use: ".$usage." seconds" ;
    
?>
Copier après la connexion
2.原因:sleep过程中被子进程返回的信号中断。

3.解决办法:

pcntl_signal(SIGCHLD, SIG_IGN ); //忽略子进程返回信号

全部代码如下

<?php // 当子进程退出时,会触发该函数
function sig_handler($sig) {
	switch($sig) {
		case SIGCHLD:
			echo 'SIGCHLD received'."n";
	}
}
  
pcntl_signal(SIGCHLD, SIG_IGN );// 注册子进程退出时调用的函数

$start          = time(); 

$sub_process_cnt = 20;
for($i=0;$i<$sub_process_cnt;$i++) { 
  
	sleep(1);   
	 
	$pid  = pcntl_fork(); 
	if ($pid == 0) {

		exit(-1);
	}
}


$status = 0;
 
for ($k=0; $k<$sub_process_cnt; $k++) 
{
	pcntl_waitpid(-1, $status );
}


$end            = time();
$usage          = $end - $start;
print "End, use: ".$usage." seconds" ;
    
?>
Copier après la connexion


Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal