【Linux】ubuntu或linux網卡配置/etc/network/interfaces

轉自:http://gfrog.net/2008/01/config-file-in-debian-interfaces-1/ubuntu

 

青蛙準備寫一個系列文章,介紹一些Debian/Ubuntu裏面經常使用的配置文件。固然,Linux系統中的配置文件多如牛毛,青蛙見過配過的也只是寥寥幾個。不過,青蛙會把配置過的配置文件儘可能詳細的介紹一下,一是方便本身之後查閱,二來也是爲廣大Debianer作貢獻了。網絡

下面開始正文。app

 

話說Debian系的網卡配置跟Redhat系很不同,Redhat是放在/etc/sysconfig/network-scripts目錄下面的一大堆文件裏面,要修改?你一個一個文件來過吧。Debian系的則是存在/etc/network/interfaces文件裏面,不管有多少塊網卡,通通扔在這個文件裏。下面就來看一下這個文件的內容。oop

首先,一個基本的配置大概是下面這個樣子:post

auto lo 
iface lo inet loopback 

# The primary network interface 
auto eth0 
iface eth0 inet static 
address 192.168.0.42 
network 192.168.0.0 
netmask 255.255.255.0 
10 
broadcast 192.168.0.255 
11 
gateway 192.168.0.1

上面的配置中,ui

第1行跟第5行說明lo接口跟eth0接口會在系統啓動時被自動配置;spa

第2行將lo接口設置爲一個本地迴環(loopback)地址;.net

第6行指出eth0接口具備一個靜態的(static)IP配置;接口

第7行-第11行分別設置eth0接口的ip、網絡號、掩碼、廣播地址和網關。ip

 

再來看一個更復雜點的:

12 auto eth0 
13 
iface eth0 inet static 
14 
address 192.168.1.42 
15 
network 192.168.1.0 
17 
netmask 255.255.255.128 
18 
broadcast 192.168.1.0 
19 
up route add -net 192.168.1.128 netmask 255.255.255.128 gw 192.168.1.2 
20 
up route add default gw 192.168.1.200 
21 
down route del default gw 192.168.1.200 
22 
down route del -net 192.168.1.128 netmask 255.255.255.128 gw 192.168.1.2

此次,有了一個複雜一些的掩碼,和一個比較奇怪的廣播地址。還有就是增長的接口啓用、禁用時的路由設置;

第19行和20行配置的左右是在接口啓用的時候,添加一條靜態路由和一個缺省路由;

第21行和22行會在接口禁用的時候,刪掉這兩條路由配置。

至於配置路由的寫法,仔細看,它就是route命令嘛。

 

繼續,下面是一個物理網卡上多個接口的配置方法:

23 auto eth0 eth0:1 
24 
iface eth0 inet static 
25 
address 192.168.0.100 
26 
network 192.168.0.0 
27 
netmask 255.255.255.0 
28 
broadcast 192.168.0.255 
29 
gateway 192.168.0.1 
30 
iface eth0:1 inet static 
31 
address 192.168.0.200 
32 
network 192.168.0.0 
33 
netmask 255.255.255.0

30行到33行在eth0上配置了另一個地址,這種配置方法在配置一塊網卡多個地址的時候很常見:有幾個地址就配置幾個接口。冒號後面的數字能夠隨便寫的,只要幾個配置的名字不重複就能夠。

 

下面是pre-up和post-down命令時間。這是一組命令(pre-up、up、post-up、pre-down、down、post-down),分別定義在對應的時刻須要執行的命令。

34 auto eth0 
35 
iface eth0 inet dhcp 
36 
pre-up [ -f /etc/network/local-network-ok ]

第36行會在激活eth0以前檢查/etc/network/local-network-ok文件是否存在,若是不存在,則不會激活eth0。

再更進一步的例子:

37 auto eth0 eth1 
38 
iface eth0 inet static 
39 
address 192.168.42.1 
40 
netmask 255.255.255.0 
41 
pre-up /path/to/check-mac-address.sh eth0 11:22:33:44:55:66 
42 
pre-up /usr/local/sbin/enable-masq 
43 
iface eth1 inet dhcp 
44 
pre-up /path/to/check-mac-address.sh eth1 AA:BB:CC:DD:EE:FF 
45 
pre-up /usr/local/sbin/firewall

第 41行和第44行中,check-mac-address.sh放在/usr/share/doc/ifupdown/examples/目錄中,使用的時候須要給它加上可執行權限。這兩行命令會檢測兩塊網卡的MAC地址是否爲11:22:33:44:55:66和AA:BB:CC:DD:EE:FF,若是正確,則啓用網卡。若是MAC地址錯誤,就不會啓用這兩塊網卡。

第42行和第45行是假定在這兩塊網卡上分別執行的命令,你能夠把它們替換成你想要的任何玩意 :)

手 冊上說,這種方法主要是用來檢測兩塊網卡的MAC地址交換(If their MAC addresses get swapped),其實就是兩塊網卡名互換了,這種狀況在debian系統上再常見不過了,主要是由於內核識別網卡的順序發生了變化。這個問題能夠用下面的這種方法來避免。

 

46 auto eth0 eth1 
47 mapping eth0 eth1 
48 script /path/to/get-mac-address.sh 
49 map 11:22:33:44:55:66 lan 
50 map AA:BB:CC:DD:EE:FF internet 
51 iface lan inet static 
52 
address 192.168.42.1 
53 netmask 255.255.255.0 
54 
pre-up /usr/local/sbin/enable-masq $IFACE 
55 
iface internet inet dhcp 
56 pre-up /usr/local/sbin/firewall $IFACE

第48行中的get-mac-address.sh也在/usr/share/doc/ifupdown/examples/目錄裏,也一樣要加可執行權限。這個腳本的做用,就是得到每塊網卡的MAC地址。

這段配置首先配置了兩個邏輯接口(這個名詞的定義請參見debian參考手冊)lan和internet,而後根據網卡的MAC地址,將邏輯接口映射(mapped)到物理接口上去。

 

再來看下面這段配置:

57 auto eth0 
 58 iface eth0 inet manual 
 59       up ifconfig $IFACE 0.0.0.0 up 
 60       up /usr/local/bin/myconfigscript  
61       down ifconfig $IFACE down

這段配置只是啓用一個網卡,可是ifupdown不對這個網卡設置任何ip,而是由外部程序來設置ip。

 

最後一段配置,這段配置啓用了網卡的混雜模式,用來當監聽接口。

177 auto eth0
178 iface eth0 inet manual 
179 
up ifconfig $IFACE 0.0.0.0 up
 180 up ip link set $IFACE promisc on 
181 down ip link set $IFACE promisc off
 182 down ifconfig $IFACE down

好了,interfaces中對於以太網卡的配置基本上介紹完了。

相關文章
相關標籤/搜索