g_SVCMsgQueIdEventRcv = msgget(MSG_DEVMON_TO_SERVICE, 0666 | IPC_CREAT); if(-1 == g_SVCMsgQueIdEventRcv) { SVC_LOG(DEBUG_K,"Create DCU event message queue failed:%s.\n",strerror(errno)); //return SVC_FAIL; }
運行上述代碼的時候,出現建立消息隊列異常,msgget返回No space left on device。app
檢查/proc/sys/kernel/msgmni裏面值爲16.這個msgmni參數決定了系統中同時運行的最大message queue的個數;ide
查看當前消息隊列,#cat /proc/sysvipc/msg,數了數有17個了,恰好超過了默認值。因此當前最後建立的這個消息隊列因空間不夠失敗。spa
修改方法:code
修改消息隊列的參數blog
1.永久修改
root用戶下修改/etc/sysctl.conf 文件。隊列
參數msgmax,msgmni,msgmnb都已經成功修改 更改的方法: 在配置文件/etc/sysctl.conf中加上 kernel.msgmax=value kernel.msgmni=value kernel.msgmnb=value 而後運行sysctl -p 便可進行修改 ip
max queues system wide = // msgmni
max size of message (bytes) = //msgmax
default max size of queue (bytes) = //msgmnbget
2.臨時修改
root用戶下sysctl -w kernel.msgmnb= 1048576消息隊列
=====io
至於代碼裏面能夠將修改命令放在啓動腳本run_application.sh;