apache 无法启动故障排查

 原贴: http://coolerfeng.blog.51cto.com/133059/81814

apache 无法启动故障排查


2008-06-13 17:21:25
 标签: apache ssl 信号量 semget   [ 推送到技术圈]

版权声明:原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。 http://coolerfeng.blog.51cto.com/133059/81814
今天在F5上逛,发现某个ip下面的机器的80和443端口down了。
于是手动重启,结果发现apachectl start,可以正常启动,apachectl startssl却不行
查看log
[Wed Apr 16 08:54:52 2008] [warn] pid file /usr/local/apache/logs/httpd.pid overwritten -- Unclean shutdown of previous Apache run?
[Fri Jun 13 11:59:24 2008] [alert] httpd: Could not determine the server's fully qualified domain name, using 127.0.0.1 for ServerName
semget: 设备上没有空间

网上查了半天也无解。试图删除/usr/local/apache/logs/httpd.pid再重启也不行。
问同事才知道
使用ipcs查看系统的信号量,发现是信号量sem已经满了,所以导致startssl无法启动。
据说是如果apache没有正常Stop掉的话,它的信号量是不会自动清除的,导致其一直滞留在内存中
于是,用以下命令清除sem信号量后,apache就可以正常启动了:
for i in `ipcs  | grep nobody | awk '{print $2}'`; do ipcrm -s $i; done

看来,以后我们需要慎用killall -9 httpd,尽量使apache能正常的stop

[root@l_192_168_131_164 log]# ipcs
------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status      
0x00000000 7143424    root      600        184324     74         dest          
------ Semaphore Arrays --------
key        semid      owner      perms      nsems      
0x00000000 0          nobody    600        1          
0x00000000 32769      nobody    600        1          
0x00000000 65538      nobody    600        1          
。。。。。。。。。
。。。。。。。。。
0x00000000 98307      nobody    600        1          
------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages  
可以看到很多
清除了就可以了
for i in `ipcs  | grep nobody | awk '{print $2}'`; do ipcrm -s $i; done
然后再查看
[root@l_192_168_132_089 /root]# ipcs
------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status      
0x00000000 8552448    root      600        184324     74         dest          
------ Semaphore Arrays --------
key        semid      owner      perms      nsems      
0x00000000 8486912    nobody    600        1          
------ Message Queues --------
key        msqid      owner      perms      used-bytes   messages  
没有那么多了。
再重新启动apache,这次正常启动了
另外一个问题,就是日志是用中文输出的,对应的错误提示在网上无法搜到,而对应的英文
semget: 设备上没有空间
semget: No space left on device
在google上很容易找到结果。看来以后要把服务器的默认语言设置为英文才行。
 
#export LC_ALL=en_US
#locale
 

本文出自 “风吹云动” 博客,请务必保留此出处http://coolerfeng.blog.51cto.com/133059/81814





     文章评论
 
2008-06-13 17:32:38
顶一下,写得真好,我什么时候才能达到这水平啊。。。

2008-06-13 18:06:39
阅览广告作品

2008-06-14 12:10:18
高人 顶啊顶

2008-06-14 12:27:34
技术内容完全看不懂,不过大概意思明白了!
就像停车似的,要正规慢慢停车才行,强行突然停车会有隐患的!
嗯,估计就是这意思!

2008-06-16 13:09:13
有前途的年轻人
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值