這篇文章主要介紹了關於PHP的pcntl進程控制之pcntl_fork,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
PHP的進程控制支援實現了Unix方式的進程創建, 程式執行, 訊號處理以及進程的中斷。進程控制不能被應用在Web伺服器環境,當其被用於Web服務環境時可能會帶來意外的結果。
這份文件用來闡述每個進程控制函數的通常用法。關於Unix進程控制的更多資訊建議您查閱系統文件中關於fork(2),waitpid(2),signal(2)等的部分或更全面的參考資料例如《Unix環境高級程式設計》(作者:W. Richard Stevens,Addison-Wesley出版)。
PCNTL現在使用了ticks作為訊號處理的回呼機制,ticks在速度上遠遠超過了先前的處理機制。這個變化與「使用者ticks」遵循了相同的語義。您可以使用declare() 語句在程式中指定允許發生回呼的位置。這使得我們對非同步事件處理的開銷最小化。在編譯PHP時 啟用pcntl將始終承擔這種開銷,無論您的腳本中是否真正使用了pcntl。
有一個調整是PHP 4.3.0之前的所有pcntl腳本要使其工作,要么在期望允許回調的(代碼)部分使用declare() ,要么使用declare()新的全局語法使其在整個腳本範圍內有效。
Note: 此擴充功能在 Windows 平台上不可用。
pcntl官方文件
# 来源官方 PHP 4 >= 4.1.0, PHP 5, PHP 7) pcntl_fork — 在当前进程当前位置产生分支(子进程)。译注:fork是创建了一个子进程,父进程和子进程 都从fork的位置开始向下继续执行,不同的是父进程执行过程中,得到的fork返回值为子进程 号,而子进程得到的是0。 说明 int pcntl_fork ( void ) pcntl_fork()函数创建一个子进程,这个子进程仅PID(进程号) 和PPID(父进程号)与其父进程不同。fork怎样在您的系统工作的详细信息请查阅您的系统 的fork(2)手册。 返回值 成功时,在父进程执行线程内返回产生的子进程的PID,在子进程执行线程内返回0。失败时,在 父进程上下文返回-1,不会创建子进程,并且会引发一个PHP错误。
<?php /** * Created by PhpStorm. * User: Object * Date: 2018/6/11 * Time: 10:12 */ const NEWLINE = "\n\n"; if (strtolower(php_sapi_name()) != 'cli') { die("请在cli模式下运行"); } echo "当前进程:" . getmypid() . NEWLINE; $pid = pcntl_fork(); //fork出子进程 //fork后父进程会走自己的逻辑,子进程从处开始走自己的逻辑,堆栈信息会完全复制给子进程内存空间,父子进程相互独立 if ($pid == -1) { // 创建错误,返回-1 die('进程fork失败'); } else if ($pid) { // $pid > 0, 如果fork成功,返回子进程id // 父进程逻辑 $time = microtime(true); echo "我是父进程:{$time}".NEWLINE; } else { // $pid = 0 // 子进程逻辑 $time = microtime(true); echo "我是子进程:{$time}".NEWLINE; }
当前进程:17472 我是父进程:1528697500.2961 我是子进程:1528697500.2961
這裡我們調換上面程式碼的父子程序的if順序
if ($pid == -1) { // 创建错误,返回-1 die('进程fork失败'); } else if (!$pid) { // $pid = 0 // 子进程逻辑 $time = microtime(true); echo "我是子进程:{$time}".NEWLINE; } else if ($pid) { // $pid > 0, 如果fork成功,返回子进程id // 父进程逻辑 $time = microtime(true); echo "我是父进程:{$time}".NEWLINE; }
当前进程:17472 我是父进程:1528697500.2961 我是子进程:1528697500.2961
fork首先會執行父進程邏輯再執行子進程邏輯
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
以上是PHP的pcntl進程控制之pcntl_fork的詳細內容。更多資訊請關注PHP中文網其他相關文章!