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

版权声明:本文为博主原创文章,可以转载但必须注明出处。 https://blog.csdn.net/nirendao/article/details/52894291

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

  1. 下载Linux内核源码 (从Linux内核代码仓库:https://git.kernel.org/)
    git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git

  2. 打包下载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 也可以将以上三步全部包括。

  1. 编译kernel的命令为 make vmlinuz
    make vmlinuz -j 8
    此处,-j 参数是让make工具采用多进程来编译。

  2. 执行编译bzImage的命令 make bzImage

  3. 执行编译内核模块的命令 make modules

安装KVM

KVM的安装包括2个步骤:module的安装, kernel和initramfs的安装

  1. 安装 module

make modules_all - 可以将编译好的module安装到相应的目录中。
在默认情况下,module被安装到 /lib/modules//kernel 目录中。

  1. 安装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客户机

暂略

阅读更多

没有更多推荐了,返回首页