標籤:原因 start exist eth 服務 linux系統 persist 解決 add
一、問題描述
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服務衝突導致,只要把該服務停止即可,查半天,本人安裝的作業系統根本就沒這個服務,哪來的衝突?
直到今天才發現原來還有太多的東西需要學習。不過我相信只要肯鑽研及善用Google與百度,還是找到瞭解決方法。
二、原因分析
使用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 系統搞定;
來自:http://www.linuxidc.com/Linux/2014-01/95253.htm
Linux啟動網卡時出現RTNETLINK answers: File exists錯誤解決方案