您的位置:首页 > 大数据 > 云计算

《KVM虚拟化技术实战和原理解析》读书笔记(二)

2016-10-22 19:36 375 查看

第三章 构建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

有配置窗口,依赖于QT

make 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客户机

暂略
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息