Ubuntu桌面下,网络是由
NetworkManager管理的。NM很好用,但是有时要配置
复杂的
网络,只能用
interfaces等网络配置文件搞定。
我给
eth0设置了静态IP,用于办公室环境(其实也是DHCP网络)。回家之后这个静态IP得不到,开机的时候会等待2分钟时间让网络起来,先显示:
Waiting for network configuration...
1分钟后是:
Waiting up to 60 more seconds for network configuration...
最后是:
Booting system without full network configuration...
这在Launchpad上有N个
bug报告。之后进入Ubuntu,
interfaces文件没有生效,而且NM都没自动启动呢。来分析一下这个问题。
现在的Ubuntu在
/etc/init.d下,System V Init任务和Upstart任务都有。如果是Upstart任务,则都链接到
/lib/init/upstart-job,如NM:
tux@macbook:/etc/init.d(0)$ ls -l network-manager
lrwxrwxrwx 1 root root 21 May 25 12:01 network-manager -> /lib/init/upstart-job
开始我看到NM在
/etc/rc?.d下没有启动脚本,就用
update-rc.d创建了链接,但还是不能自动启动。后来才明白Upstart任务的启动和停止控制不在
/etc/rc?.d目录下,而是在
/etc/init目录。NM的配置文件为
/etc/init/network-manager.conf。里面有:
start on (local-filesystems
and started dbus
and static-network-up)
就是说NM要在
local-filesystem,
dbus和
static-network-up之后才会启动,而这个Upstart Event(事件)应该是要在
interfaces中的网络接口启用之后才会发生(Emit)。所以如果
interfaces文件失效,NW也起不来。
那么开机等待的两分钟在哪里配置的呢?看了
这个文章后才知道,是在
/etc/init/failsafe.conf里面配置的。具体看该文件可以知道个大概。