Centos默認路由添加不上的問題

問題

centos出現(xiàn)一個問題,默認路由添加不上。使用

ip route add default via 10.1.1.1

這條命令添加默認路由時,不報錯,但是使用ip route命令 查看路由時,剛才添加的那一條不見了。 先說結(jié)論,原因是NetworkManager的一個BUG導(dǎo)致的。查看NetworkManager版本,1.8版本存在這個BUG。在1.10版本修復(fù),可以升級NetworkManager來解決這個問題。
在centos里面可以通過下面的命令查看NetworkManager的版本號,如果版本號低于1.10的話,可以通過升級NetworkManager來解決。

Develop>rpm -qa | grep Network
NetworkManager-team-1.8.0-9.el7.x86_64
NetworkManager-tui-1.8.0-9.el7.x86_64
NetworkManager-wifi-1.8.0-9.el7.x86_64
NetworkManager-1.8.0-9.el7.x86_64
NetworkManager-libnm-1.8.0-9.el7.x86_64

也可以修改網(wǎng)絡(luò)配置文件/etc/sysconfig/network-scripts/ifcfg-eth0,添加一行NM_CONTROLLED="no" 來解決。這里的配置文件中ifcfg-eth0要改成你的環(huán)境對應(yīng)的接口的文件。

調(diào)試過程

監(jiān)測路由變化

使用ip monitor命令監(jiān)控路由變化,終端輸入這個命令監(jiān)測,然后從另一端添加路由??梢钥吹皆谔砑幽J路由時,ip monitor監(jiān)測到路由的添加,并且發(fā)現(xiàn)路由又被刪除了。


企業(yè)微信截圖_15441653854204.png

查看NetworkManager日志

首先需要打開NetworkManager的debug級別調(diào)試開關(guān)。
默認是INFO級別的。

bingfengfeifei@bingfengfeifei-PC:~$nmcli general logging 
LEVEL  DOMAINS                                                                                                                                                                                                                   
INFO   PLATFORM,RFKILL,ETHER,WIFI,BT,MB,DHCP4,DHCP6,PPP,IP4,IP6,AUTOIP4,DNS,VPN,SHARING,SUPPLICANT,AGENTS,SETTINGS,SUSPEND,CORE,DEVICE,OLPC,INFINIBAND,FIREWALL,ADSL,BOND,VLAN,BRIDGE,TEAM,CONCHECK,DCB,DISPATCH,AUDIT,SYSTEMD,PROXY 

我們使用下面的命令調(diào)成DEBUG級別

bingfengfeifei@bingfengfeifei-PC:~$sudo nmcli general logging level debug
bingfengfeifei@bingfengfeifei-PC:~$sudo nmcli general logging            
LEVEL  DOMAINS                                                                                                                                                                                                                       
DEBUG  PLATFORM,RFKILL,ETHER,WIFI,BT,MB,DHCP4,DHCP6,PPP,IP4,IP6,AUTOIP4,DNS,VPN,SHARING,SUPPLICANT,AGENTS,SETTINGS,SUSPEND,CORE,DEVICE,OLPC,INFINIBAND,FIREWALL,ADSL,BOND,VLAN,BRIDGE,TEAM,CONCHECK,DCB,DISPATCH,AUDIT,SYSTEMD,PROXY 

然后開啟Debug之后,再添加默認路由然后,執(zhí)行journalctl -u NetworkManager來查看NetworkManager的日志。此時會看到是NetworkManager把路由刪掉了。

企業(yè)微信截圖_15441653982783.png

原因

這是因為NetworkManager的一個BUG導(dǎo)致的。1.8版本的NetworkManager中默認路由是NMDefaultRouteManager來處理的。如果手動刪除默認路由的話,會強制修改回配置文件中的默認路由,來阻止外部的修改。如果這時候配置文件中默認路由為空的話,表現(xiàn)出來的形式就是默認路由添加不上了。在NetworkManager1.10版本中NMDefaultRouteManager被廢棄了,默認路由和普通路由一樣的處理,手動添加的路由不會丟失了。
如果想要了解詳細的信息,可以查看 https://bugzilla.redhat.com/show_bug.cgi?id=1503769

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容