在 Ubuntu 15.10 上為單個網路卡設定多個 IP 地址

wjaning發表於2021-09-09

有時候你可能想在你的網路卡上使用多個 IP 地址。遇到這種情況你會怎麼辦呢?買一個新的網路卡並分配一個新的 IP?不,沒有這個必要(至少在小型網路中)。現在我們可以在 Ubuntu 系統中為一個網路卡分配多個 IP 地址。想知道怎麼做到的?跟著我往下看,其實並不難。

這個方法也適用於 Debian 以及它的衍生版本。

首先,讓我們找到網路卡的 IP 地址。在我的 Ubuntu 15.10 伺服器版中,我只使用了一個網路卡。

執行下面的命令找到 IP 地址:

sudo ip addr

樣例輸出:

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft foreverinet6 ::1/128 scope host 
valid_lft forever preferred_lft forever2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000link/ether 08:00:27:2a:03:4b brd ff:ff:ff:ff:ff:ffinet 192.168.1.103/24 brd 192.168.1.255 scope global enp0s3
valid_lft forever preferred_lft foreverinet6 fe80::a00:27ff:fe2a:34e/64 scope link 
valid_lft forever preferred_lft forever

sudo ifconfig

樣例輸出:

enp0s3 Link encap:Ethernet HWaddr 08:00:27:2a:03:4b inet addr:192.168.1.103 Bcast:192.168.1.255 Mask:255.255.255.0inet6 addr: fe80::a00:27ff:fe2a:34e/64 Scope:LinkUP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1RX packets:186 errors:0 dropped:0 overruns:0 frame:0TX packets:70 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:1000 RX bytes:21872 (21.8 KB) TX bytes:9666 (9.6 KB)lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0inet6 addr: ::1/128 Scope:HostUP LOOPBACK RUNNING MTU:65536 Metric:1RX packets:217 errors:0 dropped:0 overruns:0 frame:0TX packets:217 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:0 RX bytes:38793 (38.7 KB) TX bytes:38793 (38.7 KB)

正如你在上面輸出中看到的,我的網路卡名稱是 enp0s3,它的 IP 地址是 192.168.1.103。

現在讓我們來為網路卡新增一個新的 IP 地址,例如說 192.168.1.104。

開啟你的終端並執行下面的命令新增額外的 IP。

sudo ip addr add 192.168.1.104/24 dev enp0s3

用命令檢查是否啟用了新的 IP:

sudo ip address show enp0s3

樣例輸出:

2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000link/ether 08:00:27:2a:03:4e brd ff:ff:ff:ff:ff:ffinet 192.168.1.103/24 brd 192.168.1.255 scope global enp0s3
valid_lft forever preferred_lft foreverinet 192.168.1.104/24 scope global secondary enp0s3
valid_lft forever preferred_lft foreverinet6 fe80::a00:27ff:fe2a:34e/64 scope link 
valid_lft forever preferred_lft forever

類似地,你可以新增任意數量的 IP 地址,只要你想要。

讓我們 ping 一下這個 IP 地址驗證一下。

sudo ping 192.168.1.104

樣例輸出

PING 192.168.1.104 (192.168.1.104) 56(84) bytes of data.
64 bytes from 192.168.1.104: icmp_seq=1 ttl=64 time=0.901 ms
64 bytes from 192.168.1.104: icmp_seq=2 ttl=64 time=0.571 ms
64 bytes from 192.168.1.104: icmp_seq=3 ttl=64 time=0.521 ms
64 bytes from 192.168.1.104: icmp_seq=4 ttl=64 time=0.524 ms

好極了,它能工作!

要刪除 IP,只需要執行:

sudo ip addr del 192.168.1.104/24 dev enp0s3

再檢查一下是否刪除了 IP。

sudo ip address show enp0s3

樣例輸出:

2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000link/ether 08:00:27:2a:03:4e brd ff:ff:ff:ff:ff:ff
inet 192.168.1.103/24 brd 192.168.1.255 scope global enp0s3
valid_lft forever preferred_lft forever
inet6 fe80::a00:27ff:fe2a:34e/64 scope link 
valid_lft forever preferred_lft forever

可以看到已經沒有了!!

正如你所知,重啟系統後這些設定會失效。那麼怎麼設定才能永久有效呢?這也很簡單。

Ubuntu 系統的網路卡配置檔案是 /etc/network/interfaces。

讓我們來看看上面檔案的具體內容。

sudo cat /etc/network/interfaces

輸出樣例:

# This file describes the network interfaces available on your system# and how to activate them. For more information, see interfaces(5).source /etc/network/interfaces.d/*# The loopback network interfaceauto lo
iface lo inet loopback# The primary network interfaceauto enp0s3
iface enp0s3 inet dhcp

正如你在上面輸出中看到的,網路卡啟用了 DHCP。

現在,讓我們來分配一個額外的地址,例如 192.168.1.104/24。

編輯 /etc/network/interfaces:

sudo nano /etc/network/interfaces

如下新增額外的 IP 地址。

# This file describes the network interfaces available on your system# and how to activate them. For more information, see interfaces(5).source /etc/network/interfaces.d/*# The loopback network interfaceauto lo
iface lo inet loopback# The primary network interfaceauto enp0s3
iface enp0s3 inet dhcp
iface enp0s3 inet static
 address 192.168.1.104/24

儲存並關閉檔案。

執行下面的命令使更改無需重啟即生效。

sudo ifdown enp0s3 && sudo ifup enp0s3

樣例輸出:

Killed old client processInternet Systems Consortium DHCP Client 4.3.1Copyright 2004-2014 Internet Systems Consortium.
All rights reserved.
For info, please visit 
Listening on LPF/enp0s3/08:00:27:2a:03:4eSending on LPF/enp0s3/08:00:27:2a:03:4eSending on Socket/fallbackDHCPRELEASE on enp0s3 to 192.168.1.1 port 67 (xid=0x225f35)
Internet Systems Consortium DHCP Client 4.3.1Copyright 2004-2014 Internet Systems Consortium.
All rights reserved.
For info, please visit 
Listening on LPF/enp0s3/08:00:27:2a:03:4eSending on LPF/enp0s3/08:00:27:2a:03:4eSending on Socket/fallbackDHCPDISCOVER on enp0s3 to 255.255.255.255 port 67 interval 3 (xid=0xdfb94764)
DHCPREQUEST of 192.168.1.103 on enp0s3 to 255.255.255.255 port 67 (xid=0x6447b9df)
DHCPOFFER of 192.168.1.103 from 192.168.1.1DHCPACK of 192.168.1.103 from 192.168.1.1bound to 192.168.1.103 -- renewal in 35146 seconds.

注意:如果你從遠端連線到伺服器,把上面的兩個命令放到一行中非常重要,因為第一個命令會斷掉你的連線。而採用這種方式可以保留你的 ssh 會話。

現在,讓我們用下面的命令來檢查一下是否新增了新的 IP:

sudo ip address show enp0s3

輸出樣例:

2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000link/ether 08:00:27:2a:03:4e brd ff:ff:ff:ff:ff:ffinet 192.168.1.103/24 brd 192.168.1.255 scope global enp0s3
valid_lft forever preferred_lft foreverinet 192.168.1.104/24 brd 192.168.1.255 scope global secondary enp0s3
valid_lft forever preferred_lft foreverinet6 fe80::a00:27ff:fe2a:34e/64 scope link 
valid_lft forever preferred_lft forever

很好!我們已經新增了額外的 IP。

再次 ping IP 地址進行驗證。

sudo ping 192.168.1.104

樣例輸出:

PING 192.168.1.104 (192.168.1.104) 56(84) bytes of data.
64 bytes from 192.168.1.104: icmp_seq=1 ttl=64 time=0.137 ms
64 bytes from 192.168.1.104: icmp_seq=2 ttl=64 time=0.050 ms
64 bytes from 192.168.1.104: icmp_seq=3 ttl=64 time=0.054 ms
64 bytes from 192.168.1.104: icmp_seq=4 ttl=64 time=0.067 ms

好極了!它能正常工作。就是這樣。

想知道怎麼給 CentOS/RHEL/Scientific Linux/Fedora 系統新增額外的 IP 地址,可以點選下面的連結。

工作愉快!


譯文出處: 

via: 

作者: 譯者: 校對:


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2983/viewspace-2819842/,如需轉載,請註明出處,否則將追究法律責任。

相關文章