我正在尝试在本地服务器上设置基于 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
是可选的据我所知