Linux啟動網路卡時出現RTNETLINK answers File exists錯誤解決方法

軍說網事發表於2016-01-27

一、問題描述
VMware
中克隆虛擬機器是經常的事情,雖然如此,用到虛擬機器時,本人還是喜歡新安裝一個作業系統,針對伺服器的應用,在安裝作業系統時,一併安裝好,並且也花不了多少時間。但最近需要大量的配置一樣的虛擬機器進行測試,故安裝了一個模板虛擬機器,然後直接複製模板虛擬機器到不同的資料夾,然後使用VMware直接開啟使用,但問題出來了,開啟這些複製(克隆)的虛擬機器全部會出現網路無法啟動的問題。使用service network start  命令出現報錯如下:

device eth0 does not seem to be present
RTNETLINK answers: File exists 

RTNETLINK answers: File exists 
RTNETLINK answers: File exists

Linux蠻多年了,自認為對linux網路配置很熟悉了,我第一直覺就是MAC地址的問題,怎麼更改配置都不行,百度半天,網上很多處理方法都是說與NetworkManager服務衝突導致,只要把該服務停止即可,查半天,本人安裝的作業系統根本就沒這個服務,哪來的衝突?

直到今天才發現原來還有太多的東西需要學習。不過我相信只要肯鑽研及善用谷歌與百度,還是找到了解決方法。
 
二、原因分析

使用VMware開啟復制過來的作業系統檔案,VMware會為新產生的虛擬機器配置一個與原始虛擬機器網路卡MAC地址不同的網路卡。對於CentOS這樣的Linux系統,會把執行時的網路卡MAC地址記入到/etc/udev/rules.d/70-persistent-net.rules 檔案中。這樣克隆好的新系統裡也儲存了這個記錄。當新系統啟動時,由於vmware已經為其配置了不同的MAC地址,因此係統會在啟動掃描硬體時把這個新的MAC地址的網路卡當做是eth1,並且增加記入上述檔案中。而此時配置檔案裡的/etc/sysconfig/network-scripts/ifcfg-eth0 裡記錄的還是原來的MAC地址,而這個MAC地址在新系統裡是不存在的,所以無法啟動。
 
三、解決方法
編輯/etc/udev/rules.d/70-persistent-net.rules
找到含NAME="eth0"的那行直接刪除,如下:
SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*",ATTR{address}=="00:0c:29:ac:95:31", ATTR{type}=="1",KERNEL=="eth*", NAME="eth0"

--------------------------------------------------------------------------------
 
編輯含NAME="eth1"的那行:"eth1"更改為"eth0"

--------------------------------------------------------------------------------
 
編輯/etc/sysconfig/network-scripts/ifcfg-eth0
更改HWADDR地址跟上面rules檔案的MAC地址一樣。

--------------------------------------------------------------------------------
 

最後 init 6 或者reboot 系統搞定。




相關文章