Linux中國

如何在 Ubuntu 上搭建網橋

顧名思義,網橋的作用是通過物理介面連接內部和外部網路。對於虛擬埠或者 LXC/KVM/Xen/容器來說,這非常有用。網橋虛擬埠看起來是網路上的一個常規設備。在這個教程中,我將會介紹如何在 Ubuntu 伺服器上通過 bridge-utils (brctl) 命令行來配置 Linux 網橋。

網橋化的網路示例

圖 01: Kvm/Xen/LXC 容器網橋示例 (br0)

在這個例子中,eth0 和 eth1 是物理網路介面。eth0 連接著區域網,eth1 連接著上游路由器和互聯網。

安裝 bridge-utils

使用 apt-get 命令 安裝 bridge-utils:

$ sudo apt-get install bridge-utils

或者

$ sudo apt install bridge-utils

樣例輸出:

圖 02: Ubuntu 安裝 bridge-utils 包

在 Ubuntu 伺服器上創建網橋

使用你熟悉的文本編輯器修改 /etc/network/interfaces ,例如 vi 或者 nano :

$ sudo cp /etc/network/interfaces /etc/network/interfaces.bakup-1-july-2016
$ sudo vi /etc/network/interfaces

接下來設置 eth1 並且將它映射到 br1 ,輸入如下(刪除或者注釋所有 eth1 相關配置):

### br1 使用靜態公網 IP 地址,並以 ISP 的路由器作為網關
auto br1
iface br1 inet static
        address 208.43.222.51
        network 255.255.255.248
        netmask 255.255.255.0
        broadcast 208.43.222.55
        gateway 208.43.222.49
        bridge_ports eth1
        bridge_stp off
        bridge_fd 0
        bridge_maxwait 0

接下來設置 eth0 並將它映射到 br0,輸入如下(刪除或者注釋所有 eth0 相關配置):

auto br0
iface br0 inet static
        address 10.18.44.26
        netmask 255.255.255.192
        broadcast 10.18.44.63
        dns-nameservers 10.0.80.11 10.0.80.12
        # set static route for LAN
        post-up route add -net 10.0.0.0 netmask 255.0.0.0 gw 10.18.44.1
        post-up route add -net 161.26.0.0 netmask 255.255.0.0 gw 10.18.44.1
        bridge_ports eth0
        bridge_stp off
        bridge_fd 0
        bridge_maxwait 0

關於 br0 和 DHCP 的一點說明

如果使用 DHCP ,配置選項是這樣的:

auto br0
iface br0 inet dhcp
        bridge_ports eth0
        bridge_stp off
        bridge_fd 0
        bridge_maxwait 0

保存並且關閉文件。

重啟伺服器或者網路服務

你需要重啟伺服器或者輸入下列命令來重啟網路服務(在 SSH 登錄的會話中這可能不管用):

$ sudo systemctl restart networking

如果你證使用 Ubuntu 14.04 LTS 或者更老的沒有 systemd 的系統,輸入:

$ sudo /etc/init.d/restart networking

驗證網路配置成功

使用 ping/ip 命令來驗證 LAN 和 WAN 網路介面運行正常:

### 查看 br0 和 br1
ip a show
### 查看路由信息
ip r
### ping 外部站點
ping -c 2 cyberciti.biz
### ping 區域網伺服器
ping -c 2 10.0.80.12

樣例輸出:

圖 03: 驗證網橋的乙太網連接

現在,你就可以配置 br0 和 br1 來讓 XEN/KVM/LXC 容器訪問網際網路或者私有區域網了。再也沒有必要去設置特定路由或者 iptables 的 SNAT 規則了。

via: http://www.cyberciti.biz/faq/how-to-create-bridge-interface-ubuntu-linux/

作者:VIVEK GITE 譯者:MikeCoder 校對:wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的電子郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國