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. ",strerror(errno)); //return SVC_FAIL; }
运行上述代码的时候,出现创建消息队列异常,msgget返回No space left on device。
检查/proc/sys/kernel/msgmni里面值为16.这个msgmni参数决定了系统中同时运行的最大message queue的个数;
查看当前消息队列,#cat /proc/sysvipc/msg,数了数有17个了,刚好超过了默认值。所以当前最后创建的这个消息队列因空间不够失败。
修改方法:
修改消息队列的参数
1.永久修改
root用户下修改/etc/sysctl.conf 文件。
参数msgmax,msgmni,msgmnb都已经成功修改 更改的方法: 在配置文件/etc/sysctl.conf中加上 kernel.msgmax=value kernel.msgmni=value kernel.msgmnb=value 然后运行sysctl -p 即可进行修改
max queues system wide = // msgmni
max size of message (bytes) = //msgmax
default max size of queue (bytes) = //msgmnb
2.临时修改
root用户下sysctl -w kernel.msgmnb= 1048576
=====
至于代码里面可以将修改命令放在启动脚本run_application.sh;