为 virsh 创建 virbr0

为 virsh 创建 virbr0

我正在尝试在本地服务器上设置基于 KVM 的虚拟机,并遵循此文档:https://wiki.debian.org/KVM

在本文档中,它指出您将获得virbr0桥接连接,但不幸的是它不是自动创建的。文档建议使用 virt-manager 来解决这个问题,但我只有一个标准的 debian 服务器安装,没有 GUI。那么如何从命令行创建它呢?

我已经创建了 br0,一切看起来都不错:

$ ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast master br0 state UP group default qlen 1000
    link/ether 00:1f:c6:9c:0f:0d brd ff:ff:ff:ff:ff:ff
3: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
    link/ether 00:1f:c6:9c:0f:0d brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.200/24 brd 192.168.1.255 scope global br0
       valid_lft forever preferred_lft forever
    inet6 fe80::21f:c6ff:fe9c:f0d/64 scope link
       valid_lft forever preferred_lft forever

$ sudo ip route
default via 192.168.1.1 dev br0


$ brctl show
bridge name bridge id           STP enabled interfaces
br0         8000.001fc69c0f0d   no          eth0

注意,没有virbr0.

如果我尝试创建 ifage-bridge 我会收到错误:

$ virsh iface-bridge eth0 br0
error: failed to get interface 'eth0'
error: internal error: couldn't find interface named 'eth0': required entry missing

我还为 qemu 配置了桥接器,这是我手动完成的并将其添加到 qemu 自动启动中:

$ cat /etc/libvirt/qemu/networks/bridge.xml
<network>
  <name>bridge</name>
  <bridge name="br0"/>
  <forward mode="bridge"/>
</network>

由于桥接,我无法创建/启动虚拟机:

$ virt-install --virt-type kvm --name testvm --network bridge
Starting install...
Retrieving file MANIFEST...                  | 3.3 kB     00:00 ...
Retrieving file linux...                     | 6.0 MB     00:08 ...
Retrieving file initrd.gz...                 |  29 MB     00:56 ...
Allocating 'testvm.qcow2'                    | 8.0 GB     00:00
ERROR    failed to retrieve file descriptor for interface: Transport endpoint is not connected

如果我省略--network配置,它会起作用。这个虚拟机没有网络,所以基本上没用。如果我通过以下方式添加桥接配置virsh edit testvm

<interface type='bridge'>
  <source bridge='br0'/>
  <model type='virtio'/>
</interface>

并运行,无论如何它都会失败:

$ virsh start testvm
error: Failed to start domain testvm
error: failed to retrieve file descriptor for interface: Transport endpoint is not connected

我做错了什么?我应该如何virbr0为虚拟机添加和热设置网络?

我有一个全新的 Debian Jessie 安装,除了核心组件、ssh 和 kvm/qemu/libvirt 之外没有安装任何东西

答案1

原因是非 root 用户没有足够的权限使用网桥。

文档指出:

对于非 root,libvirt 默认为 qemu:///session。因此,从 <youruser> 您需要执行以下操作:

$ virsh --connect qemu:///system list --all

不清楚是否必须在安装时指定它,以及何时指定。事实证明,这是一个必需的非 root 用户的命令行选项。

安装具有网络功能的新虚拟机的正确命令应包括以下内容:

virt-install --connect qemu:///system .......

或者也可以直接从root用户那里安装

答案2

它应该是这样工作的:

# cat /tmp/virt-net-example.xml
<network connections='9'>
  <name>some-virt-net</name>
  <uuid>530f11c4-617b-447c-bdba-704f34374277</uuid>
  <bridge name='virbr42' stp='on' delay='0'/>
  <mac address='42:13:37:23:21:87'/>
  <ip address='172.20.42.254' netmask='255.255.255.0'>
    <dhcp>
      <range start='172.20.42.1' end='172.20.42.42'/>
    </dhcp>
  </ip>
</network>
# virsh net-define /tmp/virt-net-example.xml
# virsh net-start some-virt-net
Network some-virt-net started

# brctl show virbr42
bridge name     bridge id               STP enabled     interfaces
virbr42         8000.421337232187       yes             virbr42-nic

# link show virbr42-nic
99: virbr42-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr42 state DOWN mode DEFAULT group default qlen 1000
    link/ether 42:13:37:23:21:87 brd ff:ff:ff:ff:ff:ff

刚刚在 FC22 上针对 libvirt 1.2.13 进行了测试

答案3

您已经配置了 br0,这已经足够了。正确的虚拟安装选项是--network bridge=br0

编辑:以及连接到桥的接口示例,如评论中所承诺的:

</interface>
  <mac address='00:1a:4a:01:00:04'/>
  <source bridge='br0'/>
  <target dev='vnet2'/>
  <model type='virtio'/>
  <link state='up'/>
  <alias name='net0'/>
</interface>

target dev并且alias name是可选的据我所知

相关内容