單臺(tái)服務(wù)器的php進(jìn)程之間實(shí)現(xiàn)共享內(nèi)存的方法
來源:易賢網(wǎng) 閱讀:886 次 日期:2014-07-31 10:13:53
溫馨提示:易賢網(wǎng)小編為您整理了“單臺(tái)服務(wù)器的php進(jìn)程之間實(shí)現(xiàn)共享內(nèi)存的方法”,方便廣大網(wǎng)友查閱!

開發(fā)人員要想使php進(jìn)程實(shí)現(xiàn)共享內(nèi)存的讀寫,首先就要支持ipc函數(shù),即php編譯安裝時(shí)指定:--enable-shmop  與--enable-sysvsem 兩個(gè)選項(xiàng)。

ipc (inter-process communication) 是一個(gè)unix標(biāo)準(zhǔn)機(jī)制,它提供了使得在同一臺(tái)主機(jī)不同進(jìn)程之間可以互相的方法?;镜膇pc處理機(jī)制有3種:它們分別是共享內(nèi)存、信號(hào)量和消息隊(duì)列。本文中我們主要討論共享內(nèi)存和信號(hào)量的使用。

在不同的處理進(jìn)程之間使用共享內(nèi)存是一個(gè)實(shí)現(xiàn)不同進(jìn)程之間相互的好方法。如果你在一個(gè)進(jìn)程中向所共享的內(nèi)存寫入一段信息,那么所有其他的進(jìn)程也可以看到這段被寫入的數(shù)據(jù)。非常方便。在php中有了共享內(nèi)存的幫助,你可以實(shí)現(xiàn)不同進(jìn)程在運(yùn)行同一段php腳本時(shí)返回不同的結(jié)果?;?qū)崿F(xiàn)對php同時(shí)運(yùn)行數(shù)量的實(shí)時(shí)查詢等等。

共享內(nèi)存允許兩個(gè)或者多個(gè)進(jìn)程共享一給定的存儲(chǔ)區(qū)。因?yàn)閿?shù)據(jù)不需要在客戶機(jī)和服務(wù)器之間復(fù)制,所以這是最快的一種ipc。使用共享內(nèi)存的唯一竅門是多個(gè)進(jìn)程對一給定存儲(chǔ)區(qū)的同步存取。

如何建立一個(gè)共享內(nèi)存段呢?下面的代碼可以幫你建立共享內(nèi)存。

代碼如下:

$shm_id = shmop_open($key, $mode, $perm, $size);

注意,每個(gè)共享內(nèi)存段都有一個(gè)唯一的id, 在php中,shmop_open會(huì)把建立好的共享內(nèi)存段的id返回,這里我們用$shm_id記錄它。而$key是一個(gè)我們邏輯上表示共享內(nèi)存段的key值。不同進(jìn)程只要選擇同一個(gè)key id就可以共享同一段存儲(chǔ)段。習(xí)慣上我們用一個(gè)串(類似文件名一樣的東西)的散列值作為key id. $mode指明了共享內(nèi)存段的使用方式。這里由于是新建,因此值為'c' –取create之意。如果你是已經(jīng)建立過的共享內(nèi)存那么請用'a', 取access之意。$perm參數(shù)定義了的權(quán)限,8進(jìn)制,關(guān)于權(quán)限定義請看unix文件系統(tǒng)幫助。$size定義了共享內(nèi)存的大小。盡管有點(diǎn)象fopen(文件處理)你可不要當(dāng)它同文件處理一樣。后面的描述你將看到這一點(diǎn)。

例如:

代碼如下:

$shm_id = shmop_open(0xff3, c, 0644, 100);

這里我們打開了一個(gè)共享內(nèi)存段 鍵值0xff3 –rw-r—r—格式,大小為100字節(jié)。

如果需要已有的共享內(nèi)存段,你必須在調(diào)用shmop_open中設(shè)第3、4個(gè)參數(shù)為0。

在unix下,你可以用一個(gè)命令行程序ipcs查詢系統(tǒng)所有的ipc資源狀態(tài)。不過有些系統(tǒng)要求需要超級(jí)用戶方能執(zhí)行。下圖是一段ipcs的運(yùn)行結(jié)果。

上圖中系統(tǒng)顯示了4個(gè)共享內(nèi)存段,注意其中第4個(gè)鍵值為0x00000ff3的就是我們剛剛運(yùn)行過的php程序所創(chuàng)建的。關(guān)于ipcs的用法請參考unix用戶手冊。

如何釋放共享內(nèi)存呢

釋放共享內(nèi)存的辦法是調(diào)用php指令:shmop_delete($id)

代碼如下:

shmop_delete($id);

$id 就是你調(diào)用shmop_open所存的shmop_op的返回值。還有一個(gè)辦法就是用unix的管理指令:

ipcrm id, id就是你用ipcs看到的id.和你程序中的$id不一樣。不過要小心,如果你用ipcrm直接刪除共享內(nèi)存段那么有可能導(dǎo)致其他不知道這一情況的進(jìn)程在引用這個(gè)已經(jīng)不復(fù)存在的共享內(nèi)存器時(shí)出現(xiàn)一些不可預(yù)測的錯(cuò)誤(往往結(jié)果不妙)。

如何使用(讀寫)共享內(nèi)存呢

使用如下所示函數(shù)向共享內(nèi)存寫入數(shù)據(jù)

代碼如下:

int shmop_write (int shmid, string data, int offset)

其中shmid是用shmop_open返回的句柄。$data變量存放了要存放的數(shù)據(jù)。$offset描述了寫入從共享內(nèi)存的開始第一個(gè)字節(jié)的位置(以0開始)。

讀取操作是:

代碼如下:

string shmop_read (int shmid, int start, int count)

同樣,指明$shmid,開始偏移量(以0開始)、總讀取數(shù)量。返回結(jié)果串。這樣,你就可以把共享內(nèi)存段當(dāng)作是一個(gè)字節(jié)數(shù)組。讀幾個(gè)再寫幾個(gè),想干嘛就干嘛,十分方便。

現(xiàn)在,在單獨(dú)的一個(gè)php進(jìn)程中讀寫、創(chuàng)建、刪除共享內(nèi)存方面上你應(yīng)該沒有問題了。但是,顯然實(shí)際運(yùn)行中不可能只是一個(gè)php進(jìn)程在運(yùn)行中。如果在多個(gè)進(jìn)程的情況下你還是沿用單個(gè)進(jìn)程的處理方法,你一定會(huì)碰到問題--著名的并行和互斥問題。比如說有2個(gè)進(jìn)程同時(shí)需要對同一段內(nèi)存進(jìn)行讀寫。當(dāng)兩個(gè)進(jìn)程同時(shí)執(zhí)行寫入操作時(shí),你將得到一個(gè)錯(cuò)誤的數(shù)據(jù),因?yàn)樵摱蝺?nèi)存將之可能是最后執(zhí)行的進(jìn)程的內(nèi)容,甚至是由2個(gè)進(jìn)程寫入的數(shù)據(jù)輪流隨機(jī)出現(xiàn)的一段混合的四不象。這顯然是不能接受的。為了解決這個(gè)問題,我們必須引入互斥機(jī)制?;コ鈾C(jī)制在很多操作系統(tǒng)的教材上都有專門講述,這里不多重復(fù)。實(shí)現(xiàn)互斥機(jī)制的最簡單辦法就是使用信號(hào)燈。信號(hào)量是另外一種進(jìn)程間(ipc)的方式,它同其他ipc機(jī)構(gòu)(管道、fifo、消息隊(duì)列)不同。它是一個(gè)記數(shù)器,用于控制多進(jìn)程對共享數(shù)據(jù)的存儲(chǔ)。同樣的是你可以用ipcs和ipcrm實(shí)現(xiàn)對信號(hào)燈使用狀態(tài)的查詢和對其實(shí)現(xiàn)刪除操作。在php中你可以用下列函數(shù)創(chuàng)建一個(gè)新的信號(hào)量并返回操作該信號(hào)量的句柄。如果該key指向的信號(hào)量已經(jīng)存在,sem_get直接返回操作該信號(hào)量的句柄。

代碼如下:

int sem_get(int key [, int max_acquire [, int perm]])

$max_acquire 指明同時(shí)最多可以用幾個(gè)進(jìn)程進(jìn)入該信號(hào)而不必等待該信號(hào)被釋放(也就是最大同時(shí)處理某一資源的進(jìn)程數(shù)目,一般該值均為一)。$perm指明了權(quán)限。

一旦你成功的擁有了一個(gè)信號(hào)量,你對它所能做的只有2種:請求、釋放。當(dāng)你執(zhí)行釋放操作時(shí), 系統(tǒng)將把該信號(hào)值減一。如果小于0那就還設(shè)為0。而當(dāng)你執(zhí)行請求操作時(shí),系統(tǒng)將把該信號(hào)值加一,如果該值大于設(shè)定的最大值那么系統(tǒng)將掛起你的處理進(jìn)程直到其他進(jìn)程釋放到小于最大值為止。一般情況下最大值設(shè)為1,這樣一來當(dāng)一個(gè)進(jìn)程獲得請求時(shí)其他后面的進(jìn)程只能等待它退出互斥區(qū)后釋放信號(hào)量才能進(jìn)入該互斥區(qū)并同時(shí)設(shè)為獨(dú)占方式。這樣的信號(hào)量常稱為雙態(tài)信號(hào)量。當(dāng)然,如果初值是任意一個(gè)正數(shù)就表明有多少個(gè)共享資源單位可供共享應(yīng)用。

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)