進程通信
在各個進程中,內存空間都是不一致的,各個變量都是在不同的內存空間,舉個簡單的例子
用戶A訪問服務端,$_SESSION['user']=1;
用戶B同時訪問服務端,讀取$_SESSION['user']是讀取不到的,因為進程之間內存不是相同的
同樣,在php多進程中,pcntl_fork之后,雖然能讀取到之前的變量,但這個變量是復制出來的一份,和原來那份存儲位置根本不同,例如:
<?php
$str = "EasySwoole\n";
$pid = pcntl_fork();
if($pid>0){
$str="Tioncico\n";//在主進程修改了$str,不會影響到子進程的$str變量
echo $str;
}elseif ($pid==0){
echo $str;//$str是pcntl_fork復制出來的
}else{
}
所以,多進程中根本無法直接通信,那么,該怎么樣才能通信呢?可以使用以下幾種方式進行通信
- 管道通信,分為有名管道,無名管道等,可自行搜索了解詳細
- 消息隊列通信,使用linux消息隊列,通過sysvmsg擴展
- 進程信號通信
- 共享內存通信,映射一段能被其他進程所訪問的內存,這段共享內存由一個進程創建,但多個進程都可以訪問。共享內存是最快的 IPC 方式,它是針對其他進程間通信方式運行效率低而專門設計的。它往往與其他通信機制,如信號兩,配合使用,來實現進程間的同步和通信。
- 套接字通信
- 第三方通信,使用文件操作,mysql,redis等方法也可實現通信
可自行搜索了解詳細內容