使用与AppArmor相关的libvirt错误创建虚拟机

时间:2012-08-22 08:39:55

标签: virtualization qemu libvirt

我正在尝试使用命令创建一个使用libvirt的虚拟机:

virsh create file

"file"的内容:

<domain type='qemu' id='3'>
        <name>testvm</name>
        <memory>100</memory>
        <vcpu>1</vcpu>
        <os>
                <type arch='i686'>hvm</type>
        </os>
        <devices>
                <disk type='file' device='disk'>
                        <source file='/libtmp/VM-linux.0.2.img'/>
                        <target dev='hdc'/>
                </disk>
        </devices>
        <on_reboot>restart</on_reboot>
        <on_poweroff>preserve</on_poweroff>
        <on_crash>restart</on_crash>
</domain>

这是发生的错误。

error: Failed to create domain from file
error: internal error cannot load AppArmor profile 'libvirt-9cb01efc-ed3b-ff8e-4de5-7227d311dd15'

我可以在不加载图像文件的情况下创建vm。

每次配置文件名称都在不断变化。我试图阻止它并创建虚拟机,但我得到了同样的错误。

任何指针都会非常有用。

3 个答案:

答案 0 :(得分:5)

我有同样的问题,原因是我有一个坏主意将readonly cdrom图像放到/ etc这样:

<disk type="file" device="cdrom">
  <driver name='qemu' type="raw" />
  <source file="/etc/libvirt/qemu/cdrom.iso" />
  <target dev='hdb' bus='virtio'/>
  <readonly/>
</disk>

移至/ var删除了错误消息并允许启动虚拟机。这一行:

<source file="/var/lib/libvirt/images/cdrom.iso" />

答案 1 :(得分:4)

这是libvirt中的一个错误。见https://bugs.launchpad.net/ubuntu/+source/libvirt/+bug/665531

使用“virsh edit domainname”命令编辑虚拟域的xml定义。在xml定义中将type ='host_device'替换为type ='raw'。

答案 2 :(得分:0)

这是一种解决方法,但不是正确的方法。使用以下命令将AppArmor设置为抱怨模式:

sudo aa-complain /usr/sbin/libvirtd