当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 5 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : /etc/rc.loca有时候没有执行的问题及分析
帖子发表于 : 2009-02-13 13:09 
头像

注册: 2009-02-11 18:47
帖子: 4
送出感谢: 0 次
接收感谢: 0 次
1,
我们用ubuntu做的一台服务器,设置了每天半夜重启一次。

最近,有客户反映服务没有起来,我ssh上去一看,放在/etc/rc.local里的命令全部没有执行。只好手工启动服务。

后来,其他客户也陆续反映过类似情况,害得我只好每天一早挨个登陆客户的服务器,查看/etc/rc.local有没有执行。但这问题不是每次出现,很不好抓。

2,
今天下决心解决这问题,顺着启动流程查看配置文件。/etc/rc.local是在/etc/init.d/rc.local中调用的:
do_start() {
if [ -x /etc/rc.local ]; then
log_begin_msg "Running local boot scripts (/etc/rc.local)"
/etc/rc.local
log_end_msg $?
fi
}

但log_begin_msg是打印到console的,我们根本没有接console,就算接了,我也没法跑到客户那里去看。

3,
我把各种log都调出来看,一番大海捞针后,在/var/log/syslog里看到:
Feb 12 17:02:53 dytune-ipcc ntpdate[3298]: can't find host ntp.ubuntu.com
Feb 12 17:02:53 dytune-ipcc ntpdate[3298]: no servers can be used, exiting

顿时引起警觉,因为我们/etc/rc.local里第一个命令就是ntpdate。

于是在自己机器上做试验,把网线拔掉,不停reboot。果然,每次/etc/rc.local里的命令都没有执行,而在console上,看到了"Running local boot scripts (/etc/rc.local)",说明问题确实是ntpdate失败引起的。

照理说,ntp失败后,应该自己退出就算了,应该接着执行下面的命令,但他却连/etc/rc.local一起退出了,这个原因还要继续研究,也希望高手有以教我。

4,
现在,我把客户服务器上的ntpdate都改到最后一行去了,再继续观察。


页首
 用户资料  
 
2 楼 
 文章标题 : Re: /etc/rc.loca有时候没有执行的问题及分析
帖子发表于 : 2009-02-13 13:26 

注册: 2006-09-11 22:47
帖子: 2841
送出感谢: 0 次
接收感谢: 4
你可考虑把客户的 syslog 转发到你机器上,在/etc/syslog.conf 配置文件里面可以进行配置。

至于脚本,它有一种运行模式是:任何一个命令返回非零就退出。所以估计你的rc.local是以这种方式被运行的。


页首
 用户资料  
 
3 楼 
 文章标题 : Re: /etc/rc.loca有时候没有执行的问题及分析
帖子发表于 : 2009-02-13 13:49 
头像

注册: 2009-02-11 18:47
帖子: 4
送出感谢: 0 次
接收感谢: 0 次
谢楼上,重去看了/etc/rc.local,注释里说:

#!/bin/sh -e
#
# rc.local
#
# This script is executed at the end of each multiuser runlevel.
# Make sure that the script will "exit 0" on success or any other
# value on error.

#
# In order to enable or disable this script just change the execution
# bits.
#
# By default this script does nothing.

应该就是这意思吧。


页首
 用户资料  
 
4 楼 
 文章标题 : Re: /etc/rc.loca有时候没有执行的问题及分析
帖子发表于 : 2009-02-13 13:52 
头像

注册: 2006-07-02 11:16
帖子: 12522
地址: 廣州
送出感谢: 0 次
接收感谢: 8
/bin/sh -e

就是这个 -e 嘛..


_________________
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。


页首
 用户资料  
 
5 楼 
 文章标题 : Re: /etc/rc.loca有时候没有执行的问题及分析
帖子发表于 : 2009-02-13 15:28 
头像

注册: 2009-02-11 18:47
帖子: 4
送出感谢: 0 次
接收感谢: 0 次
man sh看了一下,确实是楼上说的原因,学艺不精啊,汗。。。


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 5 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 2 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译