1. 程式人生 > >啟動網絡卡RTNETLINK answers: File exists錯誤解決方法

啟動網絡卡RTNETLINK answers: File exists錯誤解決方法

一、問題描述

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 系統搞定.