消息队列的使用
關(guān)于消息隊(duì)列的接口函數(shù)主要參考unix環(huán)境高級(jí)編程。
剛開始看的時(shí)候,由兩個(gè)疑問(wèn),我自己的答案是這樣的
1.消息隊(duì)列在系統(tǒng)中的最大個(gè)數(shù),關(guān)于這個(gè)問(wèn)題,書上有明確的答案;書上有個(gè)表格列明了linux ,free bsd,mac OS X ,solaris中的典型值。當(dāng)然也可以通過(guò)一些手段來(lái)修改。sysctl就可以修改。
2.在多個(gè)線程(或進(jìn)程)同時(shí)對(duì)一個(gè)消息隊(duì)列進(jìn)行讀寫,是否需要同步?
? 書上沒(méi)有明確的答案,但是據(jù)猜測(cè)這個(gè)消息隊(duì)列很容易設(shè)計(jì)成用戶層不需要做同步的一個(gè)進(jìn)程間通訊方法。所以答案應(yīng)該是不需要同步(內(nèi)核已經(jīng)做了同步的處理);
后來(lái)寫了個(gè)測(cè)試程序,結(jié)果跟這個(gè)結(jié)論一致。(能看下內(nèi)核對(duì)這部分的處理就更明確了)。
?
圣經(jīng)上說(shuō):在新的應(yīng)用上最好不要使用消息隊(duì)列了。
?
提示出錯(cuò)時(shí)的一些解決辦法:
報(bào)錯(cuò)No space left on device
sysctl -w kernel.msgmni=128??
sysctl 的使用可參見:http://www.cnblogs.com/fly-fish/archive/2011/10/22/2221532.html
這條指令可以設(shè)置系統(tǒng)中同時(shí)運(yùn)行的最大的message queue的個(gè)數(shù)
查看當(dāng)前系統(tǒng)消息隊(duì)列的限制ipcs –l
ipcs工具是調(diào)試消息隊(duì)列一個(gè)很不錯(cuò)的工具。
ipcs的使用可參見:ipcs命令的使用 http://www.cnblogs.com/fly-fish/archive/2011/10/21/2220389.html
?
當(dāng)然,任何指令最詳細(xì)和明確的還是man page
轉(zhuǎn)載于:https://www.cnblogs.com/fly-fish/archive/2011/10/22/2221530.html
總結(jié)
- 上一篇: PHP中的$_COOKIE与urlenc
- 下一篇: 面向对象是软件开发范式的根本性颠覆: 主