色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

PHP中實現進程間通訊

瀏覽:3日期:2024-01-26 08:12:23

PHP中實現進程間通訊邱文宇;;本文將討論在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開始)。 讀取操作是: string shmop_read (int shmid, int start, int count) 同樣,指明$shmid,開始偏移量(以0開始)、總讀取數量。返回結果串。這樣,你就可以把共享內存段當作是一個字節數組。讀幾個再寫幾個,想干嘛就干嘛,十分方便。 多進程問題的考慮 現在,在單獨的一玫揭桓齟砦蟮氖藎蛭枚文詿娼贍蓯親詈籩蔥械慕痰哪諶藎踔潦怯?個進程寫入的數據輪流隨機出現的一段混合的四不象。這顯然是不能接受的。為了解決這個問題,我們必須引入互斥機制。互斥機制在很多操作系統的教材上都有專門講述,這里不多重復。實現互斥機制的最簡單辦法就是使用信號燈。信號量是另外一種進程間通訊(IPC)的方式,它同其他IPC機構(管道、FIFO、消息隊列)不同。它是一個記數器,用于控制多進程對共享數據的存儲。同樣的是你可以用ipcs和ipcrm實現對信號燈使用狀態的查詢和對其實現刪除操作。在PHP中你可以用下列函數創建一個新的信號量并返回操作該信號量的句柄。如果該key指向的信號量已經存在,sem_get直接返回操作該信號量的句柄。 int sem_get (int key [, int max_acquire ][, int perm]]) $max_acquire 指明同時最多可以用幾個進程進入該信號而不必等待該信號被釋放(也就是最大同時處理某一資源的進程數目,一般該值均為一)。$perm指明了訪問權限。 一旦你成功的擁有了一個信號量,你對它所能做的只有2種:請求、釋放。當你執行釋放操作時, 系統將把該信號值減一。如果小于0那就還設為0。而當你執行請求操作時,系統將把該信號值加一,如果該值大于設定的最大值那么系統將掛起你的處理進程直到其他進程釋放到小于最大值為止。一般情況下最大值設為1,這樣一來當一個進程獲得請求時其他后面的進程只能等待它退出互斥區后釋放信號量才能進入該互斥區并同時設為獨占方式。這樣的信號量常稱為雙態信號量。當然,如果初值是任意一個正數就表明有多少個共享資源單位可供共享應用。 申請、釋放操作的PHP格式如下: int sem_acquire (int sem_identifier) 申請 int sem_release (int sem_identifier) 釋放 其中sem_identifier是調用sem_get的返回值(句柄)。;;一個簡單的互斥協議例子 下面是一段很簡單的互斥操作規程。 $semid=sem_get(0xee3,1,0666); $shm_id = shmop_open(0xff3, 'c', 0644, 100); sem_acquire($semid); //申請 /* 進入臨界區*/ 這里,對共享內存進行處理 sem_release($semid); //釋放 正如你所看到的,互斥的實現很簡單:申請進入臨界區,對臨界區資源進行操作(比如修改共享內存)退出臨界區并釋放信號。這樣一來就可以保證在同一個時間片中不可能有同時2個進程對同一段共享內存進行操作。因為信號量機制保證一個時間片只能由一個進程進入,其他進程必須等待當前處理的進程完成后方能進入。 臨界區一般是指那些不允許同時有多個進程并發處理的代碼段。 要注意的是:在PHP中必須由同一個進程釋放它所占用的信號量。在一般系統中允許進程釋放別的進程占用的信號。在編寫臨界區代碼一定要小心設計資源的分配,避免A等B,B等A的死鎖情況發生。;;運用 IPC的運用是十分廣泛的。比如,在不同進程間保存一個解釋過的復雜的配置文件、或具體設置的用戶等,以避免重復處理。我也曾經用共享內存的技術把一大批PHP腳本必須引用的一個很大的文件放入共享內存,并由此顯著提升了Web服務的速度、消除了部分瓶頸。關于它的使用還有聊天室,多路廣播等等。IPC的威力取決于你的想象力的大小。如果本文對你有一點點啟發,那我不勝榮幸。愿意很你討論這令人入迷的電腦技術。Email: [email protected]

標簽: PHP
主站蜘蛛池模板: 高清日本在线成人免费视频 | 亚洲成人在线视频网站 | 中国国产一国产一级毛片视频 | 亚洲免费播放 | 亚洲国产成人精彩精品 | 亚洲视频在线观 | 国产精品久久做爰 | 亚洲成a人片在线观看中文 亚洲成a人片在线观看中文!!! | 国产激爽大片在线播放 | 免费的a级毛片 | 久久国产精品-国产精品 | 成人免费看黄网址 | 久久免费观看国产精品 | 草草视频在线观看 | 欧美成人怡红院在线观看 | 成年人看的免费视频 | 亚洲精品久久久午夜伊人 | 国产三级a三级三级三级 | 国产香蕉在线视频一级毛片 | 欧美大片无尺码在线观看 | 日韩久久一区二区三区 | 国产精品视频网址 | 成人18免费网站 | 国产精品手机在线播放 | 国产精品久久久久久搜索 | 久草热久草视频 | 亚洲第三区 | 韩国一级免费视频 | 一区两区三不卡 | 亚洲高清国产一线久久 | 91九色视频无限观看免费 | 成人黄色一级视频 | 特级毛片免费观看视频 | 精品国产成人高清在线 | 九色福利 | 日本 国产 欧美 | 欧美午夜精品一区二区三区 | 免费一级视频在线播放 | 日韩一级片在线播放 | 久热色 | 欧美一区二区三区男人的天堂 |