2010年7月12日星期一

运行级的问题

Virtualbox和dictd开机不能启动。查看/etc/rc?.d下面的脚本链接没有问题,但是runlevel输出的是unknown。我以为是Ubuntu里面的upstart已经没有runlevel的概念了,但是查看/usr/share/doc/upstart/README.Debian.gz,里面说了runlevel的概念没有变,不过是在/etc/init/rc-sysinit.conf里面定义的。我看这个文件里面又说,runlevel可以被/etc/inittab里面的设置覆盖,而我的inittab里面只有一行了,是IBM DB2的。我想应该是这个文件造成了runlevel无法正确设置。

以前装了个IBM DB2 Express-C 9.7,想学学,但是装好后从来没有碰过,这次顺便就删除算了。没想到这个软件安装容易卸载难,安装的时候有详细的文档,卸载却制造各种障碍还没有文档。按照一个DB2 Express-C的卸载步骤,才卸载掉。重启后运行级还是unknown。干脆把inittab文件删除掉,问题还是照旧。

在launchpad上Ubuntu的Bug 543506里面,看到可以查看/var/log/boot.log(由bootlogd记录)。我发现我的里面有这样的记录:

init: network-interface (lo) pre-start process (748) terminated with status 1
init: network-interface (lo) post-stop process (752) terminated with status 1
init: network-interface (eth0) pre-start process (757) terminated with status 1
init: network-interface (eth0) post-stop process (766) terminated with status 1
…………
init: networking main process (948) terminated with status 1

这表明network-interfaces脚本启动出错,进而导致iinit没没有进入到运行级2,也就没有启动/etc/rc2.d里面的启动脚本。
我想起最近用了Network Manager上上网,为了不让interfaces文件起作用,我把/etc/network/interfaces文件改名了。这正是导致networking启动不起来的原因。我把interfaces文件改回去后重启,系统的运行级成了2,/etc/init.d下下面的vboxdrv和dictd都都启动了。

在上面说的bug记录中,有人指出了问题所在,就是upstart需要lo网络接口启用才能运行成功,而Network Manager启用lo后不会通知upstart。如果确实如他所说,在我的情况里,lo在interfaces文件里面,我把这个文件改名后,lo自然不是由networking启动的,而是由network-manager启动,没有通知upstart,所以就造成了init不能启动的问题。

没有评论:

发表评论