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