第三章 构建KVM环境
3.1 硬件系统的配置
在x86-64架构的处理器中,KVM必需的硬件虚拟化扩展分别为:Intel的虚拟化技术(Intel VT)和AMD的AMD-V技术。
除了必需的处理器虚拟化扩展以外,如果服务器芯片还支持VT-d,也建议在BIOS中将其打开,因为后面一些相对高级的设备的直接分配功能会需要硬件VT-d技术的支持。VT-d(Virtualization Technology for Directed IO)是对设备I/O的虚拟化硬件支持。
在Linux系统中,可以通过检查 /proc/cpuinfo 文件中的CPU特性标志(flags)来查看CPU目前是否支持硬件虚拟化。在x86或x86-64平台中,Intel系列CPU支持虚拟化的标志为vmx,AMD系列CPU的标志为svm,所以可用如下命令行查看vmx或者svm标志。
grep -E '(vmx|svm)' /proc/cpuinfo
3.3 编译和安装KVM
下载
以下三种方式皆可:
1. 下载KVM源代码
git clone git://git.kernel.org/pub/scm/virt/kvm/kvm.git
下载Linux内核源码 (从Linux内核代码仓库:https://git.kernel.org/)
git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git打包下载Linux内核源代码(tarball)
清华的镜像站点:https://mirror.tuna.tsinghua.edu.cn/kernel/v4.x/
配置KVM
进入kvm.git之后:
- 查看帮助信息
make help
常用配置命令:
- make config
- 输入y 将该特性编译进内核
- 输入n 不将该特性编译进内核
- 输入m 将该特性作为模块进行编译
- 输入? 显示帮助信息
make oldconfig
在现有内核配置文件基础上建立一个新的配置文件,只向用户提供有关新内核特性的问题;
在新内核升级过程中,用户将现有的配置文件.config复制到新内核的源码中,执行make oldconfig,此时,用户只需要回答那些针对新特性的问题。make silentconfig
在屏幕上不再出现已经在.config中配置好的选项make menuconfig
提供了文本模式的图形用户界面make xconfig
有配置窗口,依赖于QTmake gconfig
与xconfig类似,不同点是依赖于GTK库而不是QT库make defconfig
按照内核代码中提供的默认配置文件对内核进行配置 (即 arch/x86/configs/x86_64_defconfig)make allyesconfig
尽可能多地使用 y 设置内核选项值make allnoconfig
除了必选项之外,其余选项一律不选(常用于嵌入式Linux系统的编译)make allmodconfig
尽可能多地使用 m 设置内核选项值make alllocalmodconfig
会执行 lsmod 命令查看当前系统中加载了哪些模块,并将原来.config中不需要的模块去掉,从而简化了内核的配置过程。
编译KVM
需要经过编译kernel、编译bzImage和编译module三步。其中编译bzImage这一步不是必须的。
直接执行 make 或 make all 也可以将以上三步全部包括。
编译kernel的命令为 make vmlinuz
make vmlinuz -j 8
此处,-j 参数是让make工具采用多进程来编译。执行编译bzImage的命令 make bzImage
执行编译内核模块的命令 make modules
安装KVM
KVM的安装包括2个步骤:module的安装, kernel和initramfs的安装
- 安装 module
make modules_all - 可以将编译好的module安装到相应的目录中。
在默认情况下,module被安装到 /lib/modules//kernel 目录中。
- 安装kernel和initramfs
make install - 可以安装kernel和initramfs.
可以在 /boot 目录下看见生成了的内核(vmlinuz)和 initramfs 等内核启动所需的文件。
在运行make install之后,grub配置文件(如 /boot/grub/grub.conf)中也自动添加了一个grub选项。
重启系统,就可以选择刚才为了KVM而编译、安装的内核来启动了。
通常情况下,系统启动时默认会加载 kvm 和 kvm_intel 这2个模块。若没有加载,可以手动用 modprob 命令依次加载 kvm 和 kvm_intel 模块。
modprob kvm
modprob kvm_intel
lsmod | grep kvm
确认KVM相关模块加载成功后,检查 /dev/kvm 这个文件,它是kvm内核模块提供给用户空间的qemu-kvm程序使用的一个控制接口,它提供了客户机操作系统运行所需的模拟和实际的硬件设备环境。
ls -l /dev/kvm
3.4 编译和安装qemu-kvm
下载qemu-kvm源代码
下载qemu-kvm源代码:
git clone git://git.kernel.org/pub/scm/virt/kvm/qemu-kvm.git
注:
错误:
出现问题”glib-2.12 required to compile QEMU”.
解决:
在运行 apt-cache search glib2 之后,决定运行 apt-get install libglib2.0-dev
编译 和 安装 qemu-kvm源代码
make -j 2
sudo make install
注:
错误:
在make的时候会报错,说有一个warning,而编译过程又将所有的warning当成了error.
解决:
在Makefile中找到QEMU_CFLAGS最开始出现的地方添加一行: QEMU_CFLAGS += -w
3.5 安装客户机
暂略
3.6 启动第一个KVM客户机
暂略