[TOC]
# 進程通信
******
在各個進程中,內存空間都是不一致的,各個變量都是在不同的內如空間,舉個簡單的例子:
> 用戶 A 訪問服務端,$_SESSION['user'] = 1;
> 用戶 B 同時訪問服務端,讀取$_SESSION['user']是讀取不到的,因為進程之間內存不是相同的。
同時,在 php 多進程中,pcntl_fork 之后,雖然能讀取到之前的變量,但這個變量是復制出來的一份,和原來那份存儲位置根本不同,例如:
```php
<?php
$str = "EasySwoole\n";
$pid = pcntl_fork();
if ($pid > 0) {
$str = 'huanghui\n'; // 在主進程修改了$str,不會影響到子進程的$str變量
echo $str;
} elseif ($pid == 0) {
echo $str; // $str 是 pcntl_fork復制出來的
} else {
}
```
所以,多進程中根本無法直接通信,那么,該怎么樣才能通信呢?可以使用以下幾種方式進行通信:
* 管道通信,分為有名管道、無名管道等,可自行搜索了解詳細。
* 消息隊列通信,使用 linux 消息隊列,通過 sysvmsg 擴展,可查看:[php進程通信-消息隊列](http://blog.huanghui.xyz/2019/12/16/Swoole/Swoole%E5%9F%BA%E7%A1%80/php%E8%BF%9B%E7%A8%8B%E9%80%9A%E4%BF%A1-%E6%B6%88%E6%81%AF%E9%98%9F%E5%88%97/)
* 進程信號通信,可查看:[php進程通信-進程信號](http://blog.huanghui.xyz/2019/12/24/Swoole/Swoole%E5%9F%BA%E7%A1%80/php%E8%BF%9B%E7%A8%8B%E9%80%9A%E4%BF%A1-%E8%BF%9B%E7%A8%8B%E4%BF%A1%E5%8F%B7/)
* 共享內存通信,映射一段能被其他進程所訪問的內存,這段共享內存由一個進程創建,但多個進程都可以訪問。共享內存是最快的 IPC 方式,它是針對其他進程間通信方式運行效率低而專門設計的。它往往與其他通信機制,如信號兩,配合使用,來實現進程間的同步和通信。
* 套接字通信
* 第三方通信,使用文件操作,mysql,redis等方法也可以實現通信。
可自行搜索了解詳細內容。
- 引言
- Introduction
- 運行模式
- php-fpm
- php-cli
- 基礎介紹
- 網絡協議
- ip
- tcp
- tcp
- http
- webSocket
- udp
- port端口
- 會話管理
- cookie
- session
- api/token
- linux基礎
- lnmp安裝
- 命令
- 進程管理
- 擴展安裝
- 端口監控
- 防火墻說明
- php7.0
- 部分新特性
- php回調/閉包
- 回調事件
- 閉包/匿名函數
- php多進程
- 多進程開啟
- 進程通信
- 進程信號
- 僵尸進程
- 孤兒進程
- 守護進程
- 同步/異步
- 阻塞/非阻塞
- 協程
- Swoole
- 初始Swoole
- 運行機制
- 生命周期
- composer使用
- EasySwoole
- 設計理念
- 組件說明
- 運行過程
- demo
- 提問的藝術