入门客AI创业平台(我带你入门,你带我飞行)
博文笔记

进程控制-PCNTL

创建时间:2016-12-22 投稿人: 浏览次数:160
pcntl:
	1.pcntl_alarm(int $seconds)
		创建一个计时器,在指定的秒数后向进程发送一个SIGALRM信号。每次对 pcntl_alarm()的调用都会取消之前设置的alarm信号。
		参数:
			$seconds - 等待的秒数。如果seconds设置为0,将不会创建alarm信号。
		返回值:
			返回上次alarm调度(离alarm信号发送)剩余的秒数,或者之前没有alarm调度(译注:或者之前调度已完成) 时返回0。

	2.pcntl_get_last_error()
		最后的pcntl函数调用失败时,返回的错误号

	3.pcntl_strerror(int $errno)
		根据上面返回的错误号,检索系统错误消息

	4.pcntl_errno() - 是 pcntl_strerror() 的别名

	5.pcntl_setpriority(int $priority[, int $pid = getmypid()[, int $process_identifier = PRIO_PROCESS]])
		设置进程号为 $pid 的进程的优先级
		参数:	
			$priority - 通常时-20至20这个范围内的值。默认优先级是0,值越小代表 优先级越高。由于不同的系统类型以及内核版本下优先级可能不同,因此请参考您系统的setpriority(2) 手册以获取详细的规范。
			$pid - 如果没有指定,默认是当前进程的进程号。
			$process_identifier - PRIO_PGRP(译注:获取进程组优先级), PRIO_USER (译注:获取用户进程优先级)或 PRIO_PROCESS(译注:默认值;获取进程优先级)三者之一。

	6.pcntl_getpriority([int $pid = getmypid()[, int $process_identifier = PRIO_PROCESS]])
		获取进程号为 $pid 的进程的优先级。由于不同的系统类型以及内核版本下 优先级可能不同,因此请参考您系统的getpriority(2)手册以获取详细的规范。

	7.pcntl_signal(int $signo, callback $handler[, bool $restart_syscalls = true])
		为 $signo 指定的信号安装一个新的信号处理器
		参数:
			$signo - 信号编号
			$handler - 信号处理器可以是用户创建的函数或方法的名字,也可以是系统常量 SIG_IGN(译注:忽略信号处理程序)或SIG_DFL(默认信号处理程序)
			$restart_syscalls - 指定当信号到达时系统调用重启是否可用。(译注:经查资料,此参数意为系统调用被信号打断时,系统调用是否从 开始处重新开始,但根据http://bugs.php.net/bug.php?id=52121,此参数存在bug无效。)
		示例:
			<?php
				//使用ticks需要PHP 4.3.0以上版本
				declare(ticks = 1);

				//信号处理函数
				function sig_handler($signo)
				{
				     switch ($signo) {
				         case SIGTERM:
				             // 处理SIGTERM信号
				             exit;
				             break;
				         case SIGHUP:
				             //处理SIGHUP信号
				             break;
				         case SIGUSR1:
				             echo "Caught SIGUSR1...
";
				             break;
				         default:
				             // 处理所有其他信号
				     }

				}

				echo "Installing signal handler...
";

				//安装信号处理器
				pcntl_signal(SIGTERM, "sig_handler");
				pcntl_signal(SIGHUP,  "sig_handler");
				pcntl_signal(SIGUSR1, "sig_handler");

				// 或者在PHP 4.3.0以上版本可以使用对象方法
				// pcntl_signal(SIGUSR1, array($obj, "do_something");
			?>

	8.pcntl_signal_dispatch()
		调用每个等待信号通过pcntl_signal()安装的处理器
		示例:
			<?php
				echo "安装信号处理器...
";
				pcntl_signal(SIGHUP,  function($signo) {
				     echo "信号处理器被调用
";
				});

				echo "为自己生成SIGHUP信号...
";
				posix_kill(posix_getpid(), SIGHUP);

				echo "分发...
";
				pcntl_signal_dispatch();	// 每个信号被处理器调用前,都会调用它之前的内容

				echo "完成
";
			?>
		输出:
			安装信号处理器...
			为自己生成SIGHUP信号...
			分发...
			信号处理器被调用
			完成

	9.pcntl_sigprocmask(int $how, array $set[, array &$oldset])
		增加、删除或设置阻塞信号,集体行为依赖 $how 参数
		参数:
			$how - 设置pcntl_sigprocmask()函数的行为,可选值:
				SIG_BLOCK: 把信号加入到当前阻塞信号中。
				SIG_UNBLOCK: 从当前阻塞信号中移出信号。
				SIG_SETMASK: 用给定的信号列表替换当前阻塞信号列表。
			$set - 信号列表
			$oldset - 是一个输出参数,用来返回之前的阻塞信号列表数组
		示例:
			<?php
				//将SIGHUP信号加入到阻塞信号中
				pcntl_sigprocmask(SIG_BLOCK, array(SIGHUP));
				$oldset = array();
				//将SIGHUP从阻塞信号列表中移除并返回之前的阻塞信号列表。
				pcntl_sigprocmask(SIG_UNBLOCK, array(SIGHUP), $oldset);
			?>

	10.pcntl_sigwaitinfo(array $set[, array &$siginfo])
		等待信号,pcntl_sigwaitinfo()暂停调用脚本的执行,直到接收到 $set 参数中列出的某个信号。只要其中的一个信号已经在等待状态(比如: 通过pcntl_sigprocmask()函数阻塞), 函数pcntl_sigwaitinfo()就会立刻返回。
		参数:
			$set - 要等待的信号数组
			$siginfo - 是一个输出参数,用来返回信号的信息
				以下元素会为所有信号设置:
					signo: 信号编号
					errno: 错误编号
					code: 信号代码
				下面元素可能会为SIGCHLD信号设置:
					status: 退出的值或信号
					utime: 用户消耗的时间
					stime: 系统(内核)消耗的时间
					pid: 发送进程ID
					uid: 发送进程的实际用户ID
				信号SIGILL, SIGFPE, SIGSEGV 和 SIGBUS 可能会被设置的元素:
					addr: 发生故障的内存位置
				可能会为SIGPOLL 信号设置的元素:
					band: Band event
					fd: 文件描述符
		返回值:
			返回一个信号编码
		示例:
			<?php
				echo "Blocking SIGHUP signal
";
				pcntl_sigprocmask(SIG_BLOCK, array(SIGHUP));

				echo "Sending SIGHUP to self
";
				posix_kill(posix_getpid(), SIGHUP);

				echo "Waiting for signals
";
				$info = array();
				pcntl_sigwaitinfo(array(SIGHUP), $info);
			?>

	11.pcntl_sigtimedwait(array $set[, array &$siginfo[, int $seconds = 0[, int $nanoseconds = 0]]])
		带超时机制的信号等待,函数pcntl_sigtimedwait()实际上与pcntl_sigwaitinfo() 的行为一致,不同在于它多了两个增强参数seconds和 nanoseconds,这使得脚本等待的事件有了一个时间的上限。
		参数:
			$set - 要等待的信号列表
			$siginfo - 同pcntl_sigwaitinfo()的$siginfo参数一致
			$seconds - 超时秒数
			$nanoseconds - 超时纳秒数

	12.pcntl_exec(string $path[, array $args[, array $envs]])
		在当前进程空间执行指定程序
		$path - path必须是可执行二进制文件路径或一个在文件第一行指定了 一个可执行文件路径标头的脚本(比如文件第一行是#!/usr/local/bin/perl的perl脚本)。 更多的信息请查看您系统的execve(2)手册。
		$args - args是一个要传递给程序的参数的字符串数组。
		$envs - envs是一个要传递给程序作为环境变量的字符串数组。这个数组是 key => value格式的,key代表要传递的环境变量的名称,value代表该环境变量值。

	13.pcntl_fork()
		在当前进程当前位置产生分支(子进程)。译注:fork是创建了一个子进程,父进程和子进程 都从fork的位置开始向下继续执行,不同的是父进程执行过程中,得到的fork返回值为子进程 号,而子进程得到的是0。fork怎样在您的系统工作的详细信息请查阅您的系统 的fork(2)手册。
		返回值(很关键):
			成功时,在父进程执行线程内返回产生的子进程的PID,在子进程执行线程内返回0。失败时,在 父进程上下文返回-1,不会创建子进程,并且会引发一个PHP错误。
		示例:
			<?php
				$pid = pcntl_fork();
				//父进程和子进程都会执行下面代码
				if ($pid == -1) {
				    //错误处理:创建子进程失败时返回-1.
				     die("could not fork");
				} else if ($pid) {
				     //父进程会得到子进程号,所以这里是父进程执行的逻辑
				     pcntl_wait($status); //等待子进程中断,防止子进程成为僵尸进程。
				} else {
				     //子进程得到的$pid为0, 所以这里是子进程执行的逻辑。
				}
			?>

	14.pcntl_wait(int &$status[, int $options = 0])
		1.等待或返回fork的子进程状态。pcntl_wait()函数挂起当前进程的执行,直到,一个子进程退出或接收到一个信号要求中断当前进程或调用一个信号处理函数。如果一个子进程在调用此函数时已经退出(俗称僵尸进程),此函数立刻返回。子进程使用的所有系统资源将 被释放。关于wait在您系统上工作的详细规范请查看您系统的wait(2)手册。
		2.这个函数等同于以-1作为参数pid 的值并且没有options参数来调用pcntl_waitpid() 函数。
		参数:
			$status - pcntl_wait()将会存储状态信息到status 参数上,这个通过status参数返回的状态信息可以用以下函数 pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig()以及 pcntl_wstopsig()获取其具体的值。
			$options - 如果您的操作系统(多数BSD类系统)允许使用wait3,您可以提供可选的options 参数。如果这个参数没有提供,wait将会被用作系统调用。如果wait3不可用,提供参数 options不会有任何效果。options的值可以是0 或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。可选的options有:
				WNOHANG - 如果没有子进程退出立刻返回。
				WUNTRACED - 子进程已经退出并且其状态未报告时返回。
		返回值:
			pcntl_wait()返回退出的子进程进程号,发生错误时返回-1,如果提供了 WNOHANG作为option(wait3可用的系统)并且没有可用子进程时返回0。

	15.pcntl_waitpid(int $pid, int &$status[, int $options = 0])
		等待或返回fork的子进程状态。挂起当前进程的执行直到参数pid指定的进程号的进程退出, 或接收到一个信号要求中断当前进程或调用一个信号处理函数。如果pid指定的子进程在此函数调用时已经退出(俗称僵尸进程),此函数 将立刻返回。关于waitpid更详细的规范请参见您系统的waitpid(2)手册。
		参数:
			$pid - 参数pid的值可以是以下之一:
				<-1	等待任意进程组ID等于参数pid给定值的绝对值的进程。
				-1	等待任意子进程;与pcntl_wait函数行为一致。
				0	等待任意与调用进程组ID相同的子进程。
				>0	等待进程号等于参数pid值的子进程
				注意:
					指定-1作为pid的值等同于pcntl_wait() 提供(负的options)。
			$status - pcntl_waitpid()将会存储状态信息到status 参数上,这个通过status参数返回的状态信息可以用以下函数 pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig()以及 pcntl_wstopsig()获取其具体的值。
			$options - 如果您的操作系统(多数BSD类系统)允许使用wait3,您可以提供可选的options 参数。如果这个参数没有提供,wait将会被用作系统调用。如果wait3不可用,提供参数 options不会有任何效果。options的值可以是0 或者以下两个常量或两个常量“或运算”结果(即两个常量代表意义都有效)。可选的options有:
				WNOHANG - 如果没有子进程退出立刻返回。
				WUNTRACED - 子进程已经退出并且其状态未报告时返回。
		返回值:
			pcntl_waitpid()返回退出的子进程进程号,发生错误时返回-1,如果提供了 WNOHANG作为option(wait3可用的系统)并且没有可用子进程时返回0。

	下面几个函数是进程相关的信息:
	16.pcntl_wifexited(int $status)
		检查子进程状态代码是否代表正常退出。
		参数:
			$status - 参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。
		返回值:
			当子进程状态代码代表正常退出时返回 TRUE ,其他情况返回 FALSE。

	17.pcntl_wexitstatus(int $status)
		返回一个中断的子进程的返回代码。这个函数仅在函数pcntl_wifexited()返回 TRUE 时有效。
		参数:
			$status - 参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。
		返回值:
			返回整形的子进程返回代码。

	18.pcntl_wifsignaled(int $status)
		检查子进程是否是由于某个未捕获的信号退出的。
		参数:
			$status - 参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。
		返回值:
			如果子进程是由于某个未捕获的信号退出的返回 TRUE ,其他情况返回 FALSE 。

	19.pcntl_wtermsig(int $status)
		返回导致子进程中断的信号编号。这个函数仅在 pcntl_wifsignaled() 返回 TRUE 时有效。
		参数:
			$status - 参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。
		返回值:
			返回整型的信号编号。

	20.pcntl_wifstopped(int $status)
		仅查子进程当前是否停止; 此函数只有作用于使用了WUNTRACED作为 option的pcntl_waitpid()函数调用产生的status时才有效。
		参数:
			$status - 参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。
		返回值:
			如果子进程当前是停止的返回 TRUE ,其他情况返回 FALSE 。

	21.pcntl_wstopsig(int $status)
		返回导致子进程停止的信号编号。这个函数仅在 pcntl_wifstopped()返回 TRUE 时有效。
		参数:
			$status - 参数 status 是提供给成功调用 pcntl_waitpid() 时的状态参数。
		返回值:
			返回信号编号。

声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。