PHP多进程编程

PHP有一组进程控制函数(编译时需要–enable-pcntlposix扩展),使得php能在*nix系统中实现跟c一样的创建子进程、使用exec函数执行程序、处理信号等功能。

PCNTL使用ticks来作为信号处理机制(signal handle callbackmechanism),可以最小程度地降低处理异步事件时的负载。何谓ticks?Tick 是一个在代码段中解释器每执行 N条低级语句就会发生的事件,这个代码段需要通过declare来指定。<

常用的PCNTL函数

  1. pcntl_alarm ( int $seconds )

设置一个$seconds秒后发送SIGALRM信号的计数器

  1. pcntl_signal ( int $signo , callback $handler [, bool $restart_syscalls ] )

为$signo设置一个处理该信号的回调函数。下面是一个隔5秒发送一个SIGALRM信号,并由signal_handler函数获取,然后打印一个“Caught SIGALRM”的例子:

  1. pcntl_exec ( string $path [, array $args [, array $envs ]] )

在当前的进程空间中执行指定程序,类似于c中的exec族函数。所谓当前空间,即载入指定程序的代码覆盖掉当前进程的空间,执行完该程序进程即结束。

  1. pcntl_fork ( void )

为当前进程创建一个子进程,并且先运行父进程,返回的是子进程的PID,肯定大于零。在父进程的代码中可以用

注意两点:

  1. 子进程最好有一个exit;语句,防止不必要的出错;
  2. pcntl_fork间最好不要有其它语句

  3. pcntl_wait ( int &$status [, int $options ] )

阻塞当前进程,只到当前进程的一个子进程退出或者收到一个结束当前进程的信号。使用$status返回子进程的状态码,并可以指定第二个参数来说明是否以阻塞状态调用:

  1. 阻塞方式调用的,函数返回值为子进程的pid,如果没有子进程返回值为-1;
  2. 非阻塞方式调用,函数还可以在有子进程在运行但没有结束的子进程时返回0。

  3. pcntl_waitpid ( int $pid , int &$status [, int $options ] )

功能同pcntl_wait,区别为waitpid为等待指定pid的子进程。当pid为-1时pcntl_waitpid与pcntl_wait一样。在pcntl_wait和pcntl_waitpid两个函数中的$status中存了子进程的状态信息,这个参数可以用于pcntl_wifexited、pcntl_wifstopped、pcntl_wifsignaled、pcntl_wexitstatus、pcntl_wtermsig、pcntl_wstopsig、pcntl_waitpid这些函数。

例如:

  1. pcntl_getpriority ([ int $pid [, int $process_identifier ]] )

取得进程的优先级,即nice值,默认为0,在我的测试环境的linux中(CentOS release 5.2 (Final)),优先级为-20到19,-20为优先级最高,19为最低。(手册中为-20到20)。

  1. pcntl_setpriority ( int $priority [, int $pid [, int $process_identifier ]] )

设置进程的优先级。

  1. posix_kill

可以给进程发送信号

  1. pcntl_singal

用来设置信号的回调函数

  1. 当父进程退出时,会有一个INIT进程来领养这个子进程。这个INIT进程的进程号为1,所以子进程可以通过使用getppid()来取得当前父进程的pid。如果返回的是1,表明父进程已经变为INIT进程,则原进程已经推出。
  2. 使用kill函数,向原有的父进程发送空信号(kill(pid, 0))。使用这个方法对某个进程的存在性进行检查,而不会真的发送信号。所以,如果这个函数返回-1表示父进程已经退出。