> 虚拟化 Virtualization > KVM >

配置基于Devstack的嵌套KVM虚拟化

当使用类似KVM虚拟化技术时,有个我们可以利用的优势就是嵌套虚拟化。(例如在KVM上再跑一台KVM),在云环境中运行KVM的效率会比在QEMU环境中更快。

Linux发行版中的内核默认没有开启这个嵌套虚拟化。本指南概括讲述如何在基于KVM虚拟化环境中配置启用嵌套虚拟化,如何利用嵌套虚拟化的优势在虚机中配置devstack(搭建一个云环境)

1 嵌套虚拟化配置

1.1 配置基于Intel架构的嵌套虚拟化

如何查看基于lntel架构处理器上能否使用嵌套KVM

检查如果内核参数中嵌套虚拟化是启用的

cat /sys/module/kvm_intel/parameters/nested
N

暂时移除Intel中KVM模块,然后永久开启嵌套虚拟化并重启,重启之后将KVM模块加回内核当中。

sudo rmmod kvm-intel
sudo sh -c "echo 'options kvm-intel nested=y' >> /etc/modprobe.d/dist.conf"
sudo modprobe kvm-intel

确保在处于Intel架构处理器的主机系统已经允许使用嵌套虚拟化模块

cat /sys/module/kvm_intel/parameters/nested
Y

modinfo kvm_intel | grep nested
parm:           nested:bool

开启你的虚拟机,现在你的虚机因该具有了KVM能力–你可以通过查看/dev/kvm字节设备来验证是否开启。

cat /sys/module/kvm_amd/parameters/nested
0

1.2 配置基于AMD架构的嵌套虚拟化

对于AMD架构处理器可用以下方法开启嵌套虚拟化。

sudo rmmod kvm-amd
sudo sh -c "echo 'options amd nested=1' >> /etc/modprobe.d/dist.conf"
sudo modprobe kvm-amd

确保在处于AMD架构处理器的主机系统已经允许使用嵌套虚拟化模块。

cat /sys/module/kvm_amd/parameters/nested
1

modinfo kvm_amd | grep -i nested
parm:           nested:in

再重启的时候确保以上值被永久设定,需在/etc/modprobe.d/dist.conf文件中加入以下参数:

cat /etc/modprobe.d/dist.conf
options kvm-amd nested=y


1.3 在Devstack虚机中拓展虚拟化功能

通过virsh小节来配置虚拟机libvirt XML配置项。

sudo virsh edit devstack-vm

添加以下代码片来使虚机的CPU支持这个功能。

<cpu mode='host-passthrough'>
</cpu>


1.4 确认Devstack配置的虚机使用了KVM

之前调用了stack.sh来部署Devstack的时候配置了一个虚机实例,如何确保实例开启了KVM。可以在你虚机中通过查看/dev/kvm文件来确认虚拟是否开启了KVM。Devstack将会在nova.conf配置文件中引用virt_type=kvm作为默认配置选项,否则的话Devstack会滚到默认参数virt_type=qemu即qemu仿真模式。

可以可选的显示地调用设置虚拟化类型,通过在nova中设置libvirt驱动来调用KVM。一下配置项适用于Devstack的local.conf文件中。

LIBVIRT_TYPE=kvm

一旦Devstack配置成功之后,验证Nova实例是否是启用了KVM,注意在Nova中使用accel=kvm参数将会调用QEMU的命令行。

ps -ef | grep -i qemu
root     29773     1  0 11:24 ?        00:00:00 /usr/bin/qemu-system-x86_64 -machine accel=kvm [. . .]

原文地址:http://docs.openstack.org/developer/devstack/guides/devstack-with-nested-kvm.html



(责任编辑:IT)