`
Phoenix_MVP
  • 浏览: 340382 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

【Apache】No space left on device: Couldn't create accept lock

阅读更多

问题:apache无法失败,错误日志信息如下。

 

[Wed Nov 07 10:47:53 2012] [emerg] (28)No space left on device: Couldn't create accept lock
[Wed Nov 07 10:54:09 2012] [error] (2)No such file or directory: Couldn't bind unix domain socket /home/admin/web-deploy/logs/cgisoc
k
 

 

原因:

 

(1) 确认是否是硬盘空间不足;结果发现不是空间的问题;

(2) 网上查看了下,发现是ipc不足。可以使用ipcs -s(|grep apache的group)

Apache can create the "accept lock" is with a semaphore. A semaphore is an inter-process communication tool that is used by Apache to communicate with it's child processes. This error message may mean that Apache couldn't create a new semaphore.

 

 

 

处理:

 

(1) 可以使用$ ipcrm -s <semid>清理指定 semaphore 

 

(2) 也可以使用下面命令,清理所有的semaphore, 注:替换nobody为apache对应的用户名

 

for semid in `ipcs -s | grep nobody | cut -f2 -d" "`;

do ipcrm -s $semid; done

 

 

IPC介绍:

IPC进程间通信(Inter-Process Communication)就是指多个进程之间相互通信,交换信息的方法。Linux IPC基本上都是从Unix平台上继承而来的。主要包括最初的Unix IPC,System V IPC以及基于Socket的IPC。另外,Linux也支持POSIX IPC。

IPC具体包含:(1)信号量,用来管理对共享资源的访问 (2)共享内存,用来高效地实现进程间的数据共享 (3)消息队列,用来实现进程间数据的传递。我们把这三种工具统称为System V IPC的对象,每个对象都具有一个唯一的IPC标识符(identifier)。要保证不同的进程能够获取同一个IPC对象,必须提供一个IPC关键字(IPC key),内核负责把IPC关键字转换成IPC标识符。   使用ipcs命令可以查看当前使用情况,使用ipcs -l查看系统配置参数。

 

 

 

参考:

http://hi.baidu.com/litto/item/ec10cc41c474ba96833ae1a4

http://blog.csdn.net/arganzheng/article/details/6275085

http://www.cnblogs.com/wangkangluo1/archive/2012/05/14/2498786.html

http://bbs.chinaunix.net/thread-1130381-1-1.html

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics