TranslateProject/translated/tech/20180128 How to add network bridge with nmcli (NetworkManager) on Linux.md

4.8 KiB
Raw Blame History

如何在Linux里使用nmcli NetworkManager 添加网桥

我正在电脑上使用Debian Linux 9 “stretch”。 我想用NetworkManager 来建网桥。但是根本就没有添加br0的选项。我该如何在Linux里使用nmcli 来为 NetworkManager 创建或者添加网桥呢?

网桥没什么特别的只是把两个网络连在一起。它工作在数据链路层例如OSI模型的第二层。网桥经常被虚拟机和别的一些软件使用。为了使用网桥而关闭桌面Linux上的NetworkManager 显然是不明智的。nmcli可以创建一个永久的网桥而不编辑任何文件。本文将展示如何使用NetworkManager 的命令行工具nmcli来创建网桥。

如何使用nmcli来创建/添加网桥

使用NetworkManager 在Linux上添加网桥接口的步骤如下

  1. 打开terminal
  2. 获取当前连接状态:
nmcli con show
  1. 添加新的网桥:
nmcli con add type bridge ifname br0
  1. 创建子网卡:
nmcli con add type bridge-slave ifname eno1 master br0
  1. 打开br0:
nmcli con up br0

让我们从细节层面看看如何创建一个名为br0的网桥。

获取当前网络配置

你可以通过NetworkManager的GUI来了解本机的网络连接: Getting Network Info on Linux

也可以使用如下命令行来查看:

$ nmcli con show
$ nmcli connection show --active 

View the connections with nmcli

我有一个使用网卡eno1的“有线连接”。我的系统还有一个VPN接口。我将要创建一个名为br0的网桥并连接到eno1.

如何创建一个名为br0的网桥

$ sudo nmcli con add ifname br0 type bridge con-name br0
$ sudo nmcli con add type bridge-slave ifname eno1 master br0
$ nmcli connection show

Create bridge interface using nmcli on Linux

你也可以禁用STP:

$ sudo nmcli con modify br0 bridge.stp no
$ nmcli con show
$ nmcli -f bridge con show br0

最后一条命令展示了禁用STP后的网桥参数:

bridge.mac-address:                     --
bridge.stp:                             no
bridge.priority:                        32768
bridge.forward-delay:                   15
bridge.hello-time:                      2
bridge.max-age:                         20
bridge.ageing-time:                     300
bridge.multicast-snooping:              yes

如何打开网桥

你必须先关闭"Wired connection 1" 然后打开br0:

$ sudo nmcli con down "Wired connection 1"
$ sudo nmcli con up br0
$ nmcli con show

使用 ip 命令 来查看IP信息:

$ ip a s
$ ip a s br0

Build a network bridge with nmcli on Linux

附录: 如何在KVM上使用br0

现在你可以使用KVM/VirtualBox/VMware workstation创建的VM虚拟机来直接连接网络而非通过NAT。使用vi或者cat命令cat command为虚拟机创建一个名为br0.xml的文件: $ cat /tmp/br0.xml 添加以下代码:

<network>
  <name>br0</name>
  <forward mode="bridge"/>
  <bridge name="br0" />
</network>

如下所示运行virsh命令:

# virsh net-define /tmp/br0.xml
# virsh net-start br0
# virsh net-autostart br0
# virsh net-list --all

输出:

 Name State Autostart Persistent
----------------------------------------------------------
 br0 active yes yes
 default inactive no yes

阅读man页面获取更多信息:

$ man ip
$ man nmcli

关于作者

作者是nixCraft的创建者老练的系统管理员和一个Linux/Unix shell脚本编程培训师。他为全球客户和各种公司工作包括IT教育国防空间研究以及非营利组织。 他的联系方式Twitter, Facebook, Google+.


via: https://www.cyberciti.biz/faq/how-to-add-network-bridge-with-nmcli-networkmanager-on-linux/

作者:Vivek Gite 译者:kennethXia 校对:校对者ID

本文由 LCTT 原创编译,Linux中国 荣誉推出