看了 workerman 的源码,在 fork 子进程的时候,子进程退出 用的是exit(0)。但是有的地方退出用的是 exit(250),请问为什么会有这些区别,这些数字什么意思?
exit 用法参见php手册 http://php.net/manual/zh/function.exit.php
exit($exit_code) $exit_code为0,代表进程正常退出,例如执行了reload。 $exit_code 如果是不为0的数字(0-254之间),代表异常退出,比如Exception异常,底层错误导致程序不可能继续执行时等等,要执行退出时可以加一个状态码。
主进程可以通过 http://php.net/manual/zh/function.pcntl-wait.php 获取子进程退出状态status,可以用 pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig()以及 pcntl_wstopsig()等函数计算出status对应的进程退出码,从而得知子进程是否是正常退出,因为什么原因异常退出。
例如在workerman里,如果发生业务未捕获的异常,则框架会记录日志并执行exit(250),主进程pcntl_wait会立刻捕获进程退出事件,并且status值为6400。 另外通过php start.php status 能看到哪些进程退出,status是多少,就知道发生哪些退出码,能够了解哪些进程因为什么原因退出过。 status命令参见workerman手册 http://doc3.workerman.net/advanced/status.html
谢谢 walkor 大神讲解,受益匪浅。
exit 用法参见php手册 http://php.net/manual/zh/function.exit.php
exit($exit_code) $exit_code为0,代表进程正常退出,例如执行了reload。
$exit_code 如果是不为0的数字(0-254之间),代表异常退出,比如Exception异常,底层错误导致程序不可能继续执行时等等,要执行退出时可以加一个状态码。
主进程可以通过 http://php.net/manual/zh/function.pcntl-wait.php 获取子进程退出状态status,可以用 pcntl_wifexited(), pcntl_wifstopped(), pcntl_wifsignaled(), pcntl_wexitstatus(), pcntl_wtermsig()以及 pcntl_wstopsig()等函数计算出status对应的进程退出码,从而得知子进程是否是正常退出,因为什么原因异常退出。
例如在workerman里,如果发生业务未捕获的异常,则框架会记录日志并执行exit(250),主进程pcntl_wait会立刻捕获进程退出事件,并且status值为6400。
另外通过php start.php status 能看到哪些进程退出,status是多少,就知道发生哪些退出码,能够了解哪些进程因为什么原因退出过。
status命令参见workerman手册 http://doc3.workerman.net/advanced/status.html
谢谢 walkor 大神讲解,受益匪浅。