日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

淺談并發(fā)處理PHP進(jìn)程間通信之System V IPC

瀏覽:53日期:2022-09-07 11:19:41
目錄前言Unix System V IPC信號(hào)量共享內(nèi)存消息隊(duì)列函數(shù)介紹ftoksemaphore函數(shù)shared_memory函數(shù)代碼實(shí)現(xiàn)小結(jié)前言

它的安裝和使用非常簡(jiǎn)單,在編譯 PHP 時(shí)添加 --enable-sysvsem --enable-sysvshm --enable-sysvmsg 參數(shù)就可以,當(dāng)然 Windows 上無(wú)法使用。

今天我們?nèi)耘f使用上一篇文章的例子來(lái)介紹 PHP 內(nèi)部實(shí)現(xiàn)的進(jìn)程間通信,在了解它們的具體使用之前,先簡(jiǎn)單介紹一下信號(hào)量、共享內(nèi)存、消息隊(duì)列的概念。

Unix System V IPC信號(hào)量

信號(hào)量又稱(chēng)為信號(hào)燈,它是用來(lái)協(xié)調(diào)不同進(jìn)程間的數(shù)據(jù)對(duì)象的,而最主要的應(yīng)用是共享內(nèi)存方式的進(jìn)程間通信。本質(zhì)上,信號(hào)量是一個(gè)計(jì)數(shù)器,它用來(lái)記錄對(duì)某個(gè)資源(如共享內(nèi)存)的存取狀況。

一般說(shuō)來(lái),為了獲得共享資源,進(jìn)程需要執(zhí)行下列操作:

1.獲取控制共享資源的信號(hào)量的值;

2.若值為正,進(jìn)程將信號(hào)量減1,進(jìn)程操作共享資源,進(jìn)入步驟4;

3.若值0,則拒絕進(jìn)程使用共享資源,進(jìn)程進(jìn)入睡眠狀態(tài),直至信號(hào)量值大于0后,進(jìn)程被喚醒,轉(zhuǎn)入步驟1;

4.當(dāng)進(jìn)程不再使用共享資源時(shí),將信號(hào)量值加1。如果此時(shí)有進(jìn)程正在睡眠等待此信號(hào)量,則喚醒此進(jìn)程;

信號(hào)量的使用可以類(lèi)比為:

一個(gè)房間必須用鑰匙才能開(kāi)門(mén),有N把鑰匙放在門(mén)口,拿到鑰匙開(kāi)門(mén)進(jìn)入房間,出來(lái)時(shí)將鑰匙放回并告知等待的人去取鑰匙開(kāi)門(mén)。 此例中,鑰匙的數(shù)量限制了同一時(shí)間內(nèi)在房間的最大人數(shù)。房間即共享資源,鑰匙是信號(hào)量,而想進(jìn)入房間的人則是多個(gè)進(jìn)程。

信號(hào)量有二值和多值之分,一般共享資源都不允許多個(gè)進(jìn)程同時(shí)操作,多使用二值信號(hào)量。

共享內(nèi)存

為了在多個(gè)進(jìn)程間交換信息,內(nèi)核專(zhuān)門(mén)留出了一塊內(nèi)存區(qū),可以由需要訪問(wèn)的進(jìn)程將其映射到自己的私有地址空間。進(jìn)程就可以直接讀寫(xiě)這一塊內(nèi)存而不需要進(jìn)行數(shù)據(jù)的拷貝,從而大大提高效率。共享內(nèi)存可以比喻成一塊公用黑板,每個(gè)人都能在上面留言,寫(xiě)東西。

到于共享內(nèi)存,我們一定要關(guān)心其生存周期:System V 共享內(nèi)存區(qū)域?qū)ο笫请S內(nèi)核持續(xù)的,除非顯式刪除共享內(nèi)存區(qū)域?qū)ο螅词顾性L問(wèn)共享內(nèi)存區(qū)域?qū)ο蟮倪M(jìn)程都已經(jīng)正常結(jié)束,共享內(nèi)存區(qū)域?qū)ο笕匀辉趦?nèi)核中存在,在內(nèi)核重新引導(dǎo)之前,對(duì)該共享內(nèi)存區(qū)域?qū)ο蟮娜魏胃膶?xiě)操作都將一直保留。

消息隊(duì)列

消息隊(duì)列是一條公共消息鏈,消息存取一般為先進(jìn)先出(FIFO),能實(shí)現(xiàn)多個(gè)進(jìn)程對(duì)消息的原子操作和異步存取。消息隊(duì)列的應(yīng)用十分廣泛,不光是進(jìn)程間通信,流程異步化、解耦方面也應(yīng)用廣泛。

消息隊(duì)列則相當(dāng)于一條流水線的一段,上層有多個(gè)工人把產(chǎn)品放入,下層有多個(gè)工人將產(chǎn)品取出加工。

本文的實(shí)現(xiàn)不包括消息隊(duì)列的使用,但對(duì)于消息隊(duì)列實(shí)現(xiàn)互斥鎖,這里給出一個(gè)思路:先給消息隊(duì)列初始化一個(gè)值,并發(fā)進(jìn)程競(jìng)爭(zhēng)獲取此值,獲取到值的進(jìn)程進(jìn)行共享資源的處理,進(jìn)程不再共享資源時(shí),再將此值放入隊(duì)列,通過(guò)隊(duì)列的原子性來(lái)保證同時(shí)只有一個(gè)進(jìn)程訪問(wèn)共享資源。

函數(shù)介紹ftok

int ftok ( string $pathname, string $proj )

ftok將一個(gè)路徑 pathname 和一個(gè)項(xiàng)目名(必須為一個(gè)字符), 轉(zhuǎn)化成一個(gè)整數(shù)形的 System V IPC 鍵,本文介紹的 System V 通信方式都是基于此鍵來(lái)完成的,此ID 值也可以自己指定一個(gè) INT 型來(lái)確定,不必要使用 ftok 獲取;

需要注意的是:ftok 的結(jié)果是通過(guò)文檔的索引節(jié)點(diǎn)號(hào)來(lái)計(jì)算獲取的,而文件的刪除重建會(huì)導(dǎo)致其索引節(jié)點(diǎn)號(hào)變動(dòng),所以即使是相同的文件名,也可能會(huì)導(dǎo)致獲取到的 IPC 鍵不同,所以需要盡量保證 $pathname 不變動(dòng);

semaphore函數(shù)

resource sem_get ( int $key [, int $max_acquire = 1 [, int $perm = 0666 [, int $auto_release = 1 ]]] )

獲取或生成一個(gè)信號(hào)量標(biāo)識(shí),我們注意其 max_acquire 值為 1,即保證同時(shí)只有一個(gè)進(jìn)程能獲取到它;auto_release 為 1 ,保證進(jìn)程在非正常情況退出時(shí)能釋放此信號(hào)量;

bool sem_acquire ( resource $sem_identifier [, bool $nowait = false ] )

bool sem_release ( resource $sem_identifier )

獲取/釋放一個(gè)信號(hào)量,注意獲取信號(hào)量的 $nowait 為false,使進(jìn)程在獲取信號(hào)量失敗后進(jìn)行進(jìn)程等待即可。

shared_memory函數(shù)

resource shm_attach ( int $key [, int $memsize [, int $perm = 0666 ]] )

bool shm_detach ( resource $shm_identifier )

連接/斷開(kāi) 與 共享內(nèi)存段的連接 $memsize, 以字節(jié) byte 為單位;需要注意,在第一次使用 $key 連接內(nèi)存段創(chuàng)建時(shí),會(huì)初始化內(nèi)存大小和權(quán)限,后續(xù)再連接時(shí),這兩個(gè)參數(shù)會(huì)被忽略。

bool shm_put_var ( resource $shm_identifier , int $variable_key , mixed $variable )

mixed shm_get_var ( resource $shm_identifier , int $variable_key )

向共享內(nèi)存內(nèi)寫(xiě)入或讀取一個(gè)變量,需要注意變量 key 只能是 int 型;

代碼實(shí)現(xiàn)

function getCycleIdFromSystemV($max, $min = 0) { $key = ftok(’/tmp/cycleIdFromSystemV.tok’, ’d’); $var_key = 0; $sem_id = sem_get($key); $shm_id = shm_attach($key, 4096); if (sem_acquire($sem_id)) {$cycle_id = intval(shm_get_var($shm_id, $var_key));$cycle_id++;if ($cycle_id > $max) { $cycle_id = $min;}shm_put_var($shm_id, $var_key, $cycle_id);shm_detach($shm_id);sem_release($sem_id);return $cycle_id; }return false;}小結(jié)

我們發(fā)現(xiàn) PHP 對(duì)信號(hào)量和共享內(nèi)存封裝得很好,使用起來(lái)非常簡(jiǎn)單。除此之外,PHP 的類(lèi)庫(kù) Sync 將常用 IPC 方法封裝成為類(lèi),能實(shí)現(xiàn)跨平臺(tái)的使用,感興趣的可以了解使用一下。

當(dāng)然進(jìn)程間通信的方式和種類(lèi)有很多,本文介紹的 id 遞增只是很簡(jiǎn)單的一種,不過(guò),知道了方法,再去把這些方法改造成為其他種類(lèi)也就不難了。

以上就是淺談并發(fā)處理PHP進(jìn)程間通信之System V IPC的詳細(xì)內(nèi)容,更多關(guān)于并發(fā)處理PHP進(jìn)程間通信之System V IPC的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: PHP
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲成人免费| 亚洲精品1区2区| 日韩欧美三区| 亚洲精品一二三区区别| 亚洲福利久久| 蜜桃国内精品久久久久软件9| 久久久五月天| 亚洲午夜视频| 国产亚洲高清视频| 亚洲精品免费观看| 午夜电影一区| 91伊人久久| 国产激情一区| 久久精品日韩欧美| 国产v综合v| 女同性一区二区三区人了人一 | 日韩亚洲国产欧美| 国产亚洲永久域名| 综合欧美精品| 国产精东传媒成人av电影| 日产精品一区二区| 在线国产一区二区| 午夜视频一区二区在线观看| 欧美精品二区| 日韩中文字幕高清在线观看| 婷婷综合激情| 日韩欧美三区| 日韩1区在线| 99成人在线| 国产欧美一区二区三区米奇| 毛片在线网站| 在线视频亚洲| 国产精品一区二区三区四区在线观看 | 中文日韩在线| 欧美一区在线观看视频| 色欧美自拍视频| 久久精品影视| 婷婷成人av| 激情综合婷婷| 中文一区在线| 麻豆91精品视频| 欧美亚洲国产一区| 91精品啪在线观看国产爱臀| 国产成人久久精品麻豆二区 | 亚洲少妇诱惑| 国产精品theporn| 亚洲国产综合在线看不卡| 免费精品视频在线| 精品国产亚洲一区二区在线观看| 久久久蜜桃一区二区人| 综合视频一区| 在线看片国产福利你懂的| 亚洲精品123区| 蜜桃精品视频| 在线日韩av| 国产福利一区二区三区在线播放| 五月天久久久| 欧美91在线| 国产农村妇女精品一二区| 麻豆一区在线| 日韩精品一卡二卡三卡四卡无卡| 九九九精品视频| 首页亚洲欧美制服丝腿| 国产一区二区三区日韩精品| 亚洲精品第一| 激情欧美国产欧美| 国产精品视频一区二区三区综合| 欧美日韩国产亚洲一区| 久久精品色播| 日韩一区二区三区免费视频| 日韩久久一区二区三区| 国产欧美一区二区三区精品观看| 国产毛片久久| 免费污视频在线一区| 国产精品一区二区三区av| 最新日韩av| 在线看片福利| 国产精品乱战久久久| 亚洲欧美成人综合| www.com.cn成人| 国产精品巨作av| 日韩中文一区二区| 在线日韩中文| 成人小电影网站| 欧美在线黄色| 夜夜嗨网站十八久久| 国产v综合v| 国产96在线亚洲| 国产亚洲精品美女久久久久久久久久| 国产亚洲精品v| 亚洲高清二区| 久久久久国产一区二区| 色欧美自拍视频| 国产激情一区| 国产毛片一区二区三区| 蜜桃视频在线观看一区二区| 欧美精品羞羞答答| 日韩精品午夜| 日韩欧美精品一区| 精品视频黄色| 欧美激情99| 美腿丝袜亚洲一区| 国产精品a级| 国产精品一区二区三区美女| 日韩av一二三| 日韩精品a在线观看91| 免费在线欧美视频| 亚洲欧美日韩视频二区| 亚洲欧美日韩高清在线| 日韩精品一卡| 久久久久国产一区二区| 婷婷激情一区| 高清在线一区| 亚洲深夜视频| 不卡一二三区| 中文字幕在线看片| 日韩在线视频精品| 99久久亚洲精品| 今天的高清视频免费播放成人| 久久一级电影| 不卡一区综合视频| 91久久中文| 亚洲最大av| 青青伊人久久| 久久不见久久见免费视频7| 免费在线观看一区| 国产v日韩v欧美v| 肉色欧美久久久久久久免费看| 国产精品原创| 欧美gv在线| 亚洲福利久久| 亚洲欧美日韩一区在线观看| 综合一区二区三区| 三级久久三级久久久| 日本不卡不码高清免费观看| 欧美亚洲三区| 成人午夜亚洲| 欧美中文一区二区| 丝瓜av网站精品一区二区| 日韩中文字幕一区二区高清99| 久久国内精品视频| 精品中文字幕一区二区三区四区| av资源亚洲| 99国产精品99久久久久久粉嫩| 欧美日韩视频| 亚洲1区在线观看| 久久99视频| 久久久久国产精品一区三寸| 国产亚洲永久域名| 久久精品av麻豆的观看方式| 乱一区二区av| 久久久亚洲一区| 亚洲香蕉视频| 国产高清精品二区| 精品捆绑调教一区二区三区| aa国产精品| 国产精一区二区| 国产亚洲一区二区手机在线观看 | 亚洲毛片一区| 久久精品一本| 好吊视频一区二区三区四区| 青草国产精品久久久久久| 麻豆视频在线看| 欧美一区=区| 国产高清视频一区二区| 激情综合网五月| 国产亚洲一区二区三区不卡| 日韩亚洲一区在线| 蜜臀av亚洲一区中文字幕| 精品伊人久久久| 精品在线99| 国产日韩欧美中文在线| 日韩一区欧美| 日本成人在线不卡视频| av在线日韩| 日本三级亚洲精品| 久久蜜桃精品| 国产欧美丝祙| 精品91久久久久| 欧美a级一区二区| 国产免费成人| 日韩成人免费| 日本不卡不码高清免费观看| 日韩一区自拍| 欧美日韩va| 激情欧美亚洲| 国产精品99久久免费| 夜久久久久久| 成人在线黄色| 少妇精品久久久| 欧美亚洲激情| 免费在线播放第一区高清av| 亚洲午夜精品久久久久久app| 欧美亚洲综合视频| 欧美日韩激情在线一区二区三区| 国产精品久久久免费| 亚洲一区区二区| 老牛影视精品| 91麻豆精品激情在线观看最新 | 午夜性色一区二区三区免费视频|