導讀作為一個 Ubuntu 16.04 LTS 的初學者。如何在 Ubuntu 14.04 和 16.04 的主機上搭建網橋呢?顧名思義,網橋的作用是通過物理接口連接內部和外部網絡。對於虛擬端口或者 LXC/KVM/Xen/容器來說,這非常有用。網橋虛擬端口看起來是網絡上的一個常規設備。在這個教程中,我將會介紹如何在 Ubuntu 服務器上通過 bridge-utils (brctl) 命令行來配置 Linux 網橋。
圖 01: Kvm/Xen/LXC 容器網橋示例 (br0)
在這個例子中,eth0 和 eth1 是物理網絡接口。eth0 連接着局域網,eth1 連接着上游路由器和互聯網。
使用 apt-get 命令安裝 bridge-utils:
$ sudo apt-get install bridge-utils
或者
$ sudo apt install bridge-utils
樣例輸出:
圖 02: Ubuntu 安裝 bridge-utils 包
使用你熟悉的文本編輯器修改
/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
如果使用 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 規則了。
免費提供最新Linux技術教程書籍,為開源技術愛好者努力做得更多更好:https://www.linuxprobe.com/