本文將討論在PHP4環境下如何運用進程間通訊機制——IPC(INTER-PROCESS-COMMUNICATION)。本文討論的軟件環境是LINUX+PHP4.0.4或更高版本。首先,我們假設你已經裝好了PHP4和UNIX, 為了使得PHP4可以運用共享內存和信號量,必須在編譯PHP4順序時激活SHMOP和SYSVSEM這兩個擴展模塊。
實現方法:在PHP設定(CONFIGURE)時加入如下選項。
--ENABLE-SHMOP --ENABLE-SYSVSEM  
這樣就使得你的PHP系統可以處理相關的IPC函數了。
IPC是什么?
IPC (INTER-PROCESS COMMUNICATION) 是一個UNIX標準通訊機制,它提供了使得在同一臺主機不同進程之間可以互相通訊的方法。基本的IPC處理機制有3種:它們分別是共享內存、信號量和消息隊列。本文中我們次要討論共享內存和信號量的運用。關于消息隊列,筆者在不久的將來還會專門介紹。
在PHP中運用共享內存段
在不同的處理進程之間運用共享內存是一個實現不同進程之間相互通訊的好方法。如果你在一個進程中向所共享的內存寫入一段信息,那么所有其他的進程也可以看到這段被寫入的數據。非常方便。在PHP中有了共享內存的幫助,你可以實現不同進程在運行同一段PHP腳本時返回不同的結果。或實現對PHP同時運行數量的實時查詢等等。
共享內存允許兩個或者多個進程共享一給定的存儲區。因為數據不需要在客戶機和服務器之間復制,所以這是最快的一種IPC。運用共享內存的唯一訣竅是多個進程對一給定存儲區的同步存取。
如何建立一個共享內存段呢?下面的代碼可以幫你建立共享內存。
$SHM_ID = SHMOP_OPEN($KEY, $MODE, $PERM, $SIZE);
注意,每個共享內存段都有一個唯一的ID, 在PHP中,SHMOP_OPEN會把建立好的共享內存段的ID返回,這里我們用$SHM_ID記錄它。而$KEY是一個我們邏輯上表示共享內存段的KEY值。不同進程只要選擇同一個KEY ID就可以共享同一段存儲段。習慣上我們用一個串(類似文件名一樣的東西)的散列值作為KEY ID. $MODE指明了共享內存段的運用方式。這里由于是新建,因此值為’C’ –取CREATE之意。如果你是訪問已經建立過的共享內存那么請用’A’,-- 取ACCESS(小型網站之最愛)之意。$PERM參數定義了訪問的權限,8進制,關于權限定義請看UNIX文件系統幫助。$SIZE定義了共享內存的大小。盡管有點象FOPEN(文件處理)你可不要當它同文件處理一樣。后面的描述你將看到著一點。
例如:
$SHM_ID = SHMOP_OPEN(0XFF3, "C", 0644, 100);
這里我們打開了一個共享內存段 鍵值0XFF3 –RW-R—R—格式,大小為100字節。
如果需要訪問已有的共享內存段,你必須在調用SHMOP_OPEN中設第3、4個參數為0。
IPC工作狀態的查詢
在UNIX下,你可以用一個命令行順序IPCS查詢系統所有的IPC資源狀態。不過有些系統要求需要超級用戶方能執行。下圖是一段IPCS的運行結果。  


上圖中系統顯示了4個共享內存段,注意其中第4個鍵值為0X00000FF3的就是我們剛剛運行過的PHP順序所創建的。關于IPCS的用法請參考UNIX用戶手冊。
如何釋放共享內存呢
釋放共享內存的辦法是調用PHP指令:SHMOP_DELETE($ID)
SHMOP_DELETE($ID);
$ID 就是你調用SHMOP_OPEN所存的SHMOP_OP的返回值。還有一個辦法就是用UNIX的管理指令:
IPCRM ID, ID就是你用IPCS看到的ID.和你順序中的$ID不一樣。不過要小心,如果你用IPCRM直接刪除共享內存段那么有可能導致其他不知道這一情況的進程在引用這個已經不復存在的共享內存器時出現一些不可預測的錯誤(往往結果不妙)。
如何運用(讀寫)共享內存呢
運用如下所示函數向共享內存寫入數據
INT SHMOP_WRITE (INT SHMID, STRING DATA, INT OFFSET)
其中SHMID是用SHMOP_OPEN返回的句柄。$DATA變量存放了要存放的數據。$OFFSET描述了寫入從共享內存的開始第一個字節的位置(以0開始)。

/Files/xiaomage234/shmop.rar