Job for network.service failed because the control process exited with error code問題
今天在centOS 7下更改完靜態(tài)ip后發(fā)現(xiàn)network服務重啟不了,翻遍了網(wǎng)絡,嘗試了各種方法,終于解決了。
現(xiàn)把各種解決方法歸納整理,希望能讓后面的同學少走點歪路。。。
首先看問題:執(zhí)行
service network restart
命令后出現(xiàn)下面的錯誤:
Restarting network(via systemctl):Job for network.service failed because the control process exited with error code.See"systemctl status network.service"and"journalctl -xe"for details. [失敗]
根據(jù)提示輸入
systemctl status network.service
命令后出現(xiàn)如下錯誤信息:
1.`● network.service - LSB: Bring up/down networking`2.`Loaded: loaded (/etc/rc.d/init.d/network; bad; vendor preset: disabled)`3.`Active: failed (Result: exit-code) since 五 2017-07-14 19:01:47 CST; 1min 16s ago`4.`Docs: man:systemd-sysv-generator(8)`5.`Process: 4681 ExecStart=/etc/rc.d/init.d/network start (code=exited, status=1/FAILURE)`6.`CGroup: /system.slice/network.service`7.`└─1192 /sbin/dhclient -H mini1 -1 -q -lf /var/lib/dhclient/dhclient--ens33.lease -pf /v...`9.`7月 14 19:01:47 mini1 network[4681]: RTNETLINK answers: File exists`10.`7月 14 19:01:47 mini1 network[4681]: RTNETLINK answers: File exists`11.`7月 14 19:01:47 mini1 network[4681]: RTNETLINK answers: File exists`12.`7月 14 19:01:47 mini1 network[4681]: RTNETLINK answers: File exists`13.`7月 14 19:01:47 mini1 network[4681]: RTNETLINK answers: File exists`14.`7月 14 19:01:47 mini1 network[4681]: RTNETLINK answers: File exists`15.`7月 14 19:01:47 mini1 systemd[1]: network.service: control process exited, code=exited status=1`16.`7月 14 19:01:47 mini1 systemd[1]: Failed to start LSB: Bring up/down networking.`17.`7月 14 19:01:47 mini1 systemd[1]: Unit network.service entered failed state.`18.`7月 14 19:01:47 mini1 systemd[1]: network.service failed.`
network服務啟動不了首先保證/etc/sysconfig/network-scripts目錄下的ifcfg-xxx(每臺機器不一定相同)沒有錯誤(如果你改動過的話),這里的錯誤指的在更改過程中因為手誤敲錯字母之類的。
網(wǎng)上最常見的幾種做法如下:
1.和 NetworkManager 服務有沖突,這個好解決,直接關閉 NetworkManger 服務就好了,
service NetworkManager stop #關閉 NetworkManger 服務
chkconfig NetworkManager off? #并且禁止開機啟動 , 之后重啟就好了。
2和配置文件的MAC地址不匹配,這個也好解決,使用ip addr(或ifconfig)查看mac地址
1.`1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1`2.`link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00`3.`inet 127.0.0.1/8 scope host lo`4.`valid_lft forever preferred_lft forever`5.`inet6 ::1/128 scope host`6.`valid_lft forever preferred_lft forever`7.`2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000`8.`link/ether 00:0c:29:b8:e7:21 brd ff:ff:ff:ff:ff:ff`9.`inet 192.168.65.141/24 brd 192.168.65.255 scope global dynamic ens33`10.`valid_lft 1193sec preferred_lft 1193sec`11.`inet6 fe80::cca2:d835:f93:e637/64 scope link`12.`valid_lft forever preferred_lft forever`
00:0c:29:b8:e7:21這個就是MAC地址了,將/etc/sysconfig/network-scripts/ifcfg-xxx中的HWADDR(如果沒有就添加上)改成這個MAC地址
3.設定開機啟動一個名為NetworkManager-wait-online服務,命令為:
systemctl enable NetworkManager-wait-online.service
=========================================================================================================
上面兩個是我看到最多的解決方法,但是很遺憾,我的并沒有解決。
有查看資料,發(fā)現(xiàn)了以下一些方法:
4.查看/etc/sysconfig/network-scripts下,將其余無關的網(wǎng)卡位置文件全刪掉,避免不必要的影響,即只留一個以ifcfg開頭的文件,
留的那一個應和使用ip addr命令查看ip第二條開頭的名稱一致(我的是ens33,參見上面我貼出的ip addr命令執(zhí)行結果),所以我只留了一個ifcfg-ens33。(我的其中兩臺機器就是這么弄好的,因為我在修改前留了備份,把備份刪掉就好了。。。)
5.將ifcfg-xxx文件中的DEVICE一行注釋掉。
6.將ifcfg-xxx中的NAME改為和文件名一致。
7.在VMWare的編輯-虛擬網(wǎng)絡編輯器中將網(wǎng)絡模式改為橋接。
8.看VMWare右下角的網(wǎng)絡適配器是否連接,如果沒有連接則連接上。
image
(補充:點擊網(wǎng)絡適配器-設置,將NAT模式改為橋接試試,我的改為橋接后可以重啟network服務了但是上不了網(wǎng),可以重啟后
再將橋接模式改為NAT模式,發(fā)現(xiàn)既可以上網(wǎng)又可以重啟network服務了)
9.查看下你電腦有沒有禁用了VMware DHCP service和VMware NAT service 這幾個vm服務,如果禁用則開啟。
10 .如果你改成了靜態(tài)ip別忘了將BOOTPROTO改為static。
11.如果以上都沒有解決,還有最后一招-- 重啟 看一看有沒有奇跡發(fā)生?。。ㄎ业牧硗庖慌_重啟后莫名就好了)
上面這些方法,我基本都試過了,對我的機器有的有用有的沒用,但是有人也用這些方法解決了,所以一并記錄下來。希望能給予你一點幫助