kvm介绍

一、KVM的历史

Kvm在2007年2月正式合并Linux2.6.20核心中,成为内核源代码的一部分。2008年9月4日,RedHat公司收购了Qumranet,开始在RHEL中用kvm取代Xen,第一包kvm的版本的是RHEL5.4。从RHEL6开始,kvm成为默认的虚拟化引擎。Kvm必须在具备IntelT或AMD-V功能的X86平台上运行。它也被移植到S/390、PowerPC与IA-64平台上。在Linux内核3.9版中,加入了对ARM架构的支持。

二、KVM的架构

 KVM的架构非常简单,它其实就是一个内核的模块,用户空间通过QEMU模拟硬件提供给虚拟机使用,一台虚拟机就是一个普通的Linux进程,通过对这个进程管理,就可以完成对虚拟机的管理。

支持kvm的安卓内核 kvm版本和内核版本_开发工具

三、QEMU与KVM

QEMU是一个开源项目,实际上是一台硬件模拟器,可以在其它平台上运行Linux程序,可以存储及还原虚拟机运行状态,还可以虚拟多种设备,包括网卡、多CPU、IDE设备、软驱、显卡、声卡、多种并口设备、多种串口设备、多种USB设备、PC喇叭、PS/2键盘鼠标(默认)和USB键盘鼠标、蓝牙设备。

QEMU的优点是因为纯软件模拟,所以可以在支持的平台模拟支持的设备。它的缺点也是因为纯软件模拟,所以非常慢。

KVM是一个内核模块,没有用户空间和管理工具,KVM的虚拟机可以借助QEMU的管理工具来管理。QEMU也可以借助KVM来加速,提升虚拟机的性能。

四、Libvirt与KVM

Libvirt的设计目标是通过相同的方式管理不同的虚拟化引擎,比如KVM、Xen、HyperV、VMware ESX等。但是目前实际上多数场景使用Libvirt的是KVM,而Xen、HyperV、VMware ESX都有各自的管理工具。

Libvirt可以实现对虚拟机的管理,比如虚拟机的创建、启动、关闭、暂停、恢复、迁移、销毁,以及虚拟机网卡、硬盘、CPU、内存等多种设备的热添加。

支持kvm的安卓内核 kvm版本和内核版本_支持kvm的安卓内核_02

配置安装

一、 操作系统最小化安装并关闭SELinux、Network Manager和防火墙,并配置主机名、IP地址、DNS解析



[root@kvm-server ~]# uname -a
Linux kvm-server 3.10.0-327.el7.x86_64 #1 SMP Thu Nov 19 22:10:57 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux
[root@kvm-server ~]# cat /etc/redhat-release 
CentOS Linux release 7.2.1511 (Core) 
[root@kvm-server ~]# sed -i 's#SELINUX=enforcing#SELINUX=disabled#g' /etc/selinux/config 
[root@kvm-server ~]# setenforce 0
[root@kvm-server ~]# systemctl stop NetworkManager
[root@kvm-server ~]# systemctl disable NetworkManager
[root@kvm-server ~]# systemctl stop firewalld
[root@kvm-server ~]# systemctl disable firewalld



二、安装阿里源EPEL源



[root@kvm-server ~]# rpm -ivh http://mirrors.aliyun.com/epel/epel-release-latest-7.noarch.rpm



三、安装常用命令



[root@kvm-server ~]# yum install net-tools vim lrzsz tree screen lsof tcpdump nc mtr nmap openssl-devel ntpdate sysstat -y



四、查看CPU虚拟化是否打开(能过滤到内容表示开启)



[root@kvm-server ~]# egrep '(vmx|svm)' /proc/cpuinfo



五、安装KVM软件包



[root@kvm-server ~]# yum install qemu-kvm libvirt virt-install -y



六、启动libvirtd服务



[root@kvm-server ~]# systemctl start libvirtd
[root@kvm-server ~]# systemctl enable libvirtd



七、检查是否安装成功、KVM模块是否载入成功、KVM是否安装成功



[root@kvm-server ~]# rpm -qa | egrep 'qemu-img|libvirt-[1-9]|virt-install'
libvirt-3.9.0-14.el7_5.8.x86_64
qemu-img-1.5.3-156.el7_5.5.x86_64
virt-install-1.4.3-3.el7.noarch
[root@kvm-server ~]#  lsmod |grep kvm
kvm_intel             162153  0 
kvm                   525259  1 kvm_intel
[root@kvm-server ~]# virsh -c qemu:///system list
 Id    Name                           State
----------------------------------------------------



八、启动libvirtd后会自动创建一个桥接网卡virbr0



[root@kvm-server ~]# brctl show
bridge name    bridge id        STP enabled    interfaces
virbr0        8000.5254008deb7b    yes        virbr0-nic
[root@kvm-server ~]# ifconfig virbr0
virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:54:00:8d:eb:7b  txqueuelen 0  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0



九、手动配置桥接网络



[root@kvm-server ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0  #修改ifcfg-eth0配置文件
DEVICE=eth0
TYPE=Ethernet
ONBOOT=yes
BRIDGE=br0
[root@kvm-server ~]# cat /etc/sysconfig/network-scripts/ifcfg-br0   #修改ifcfg-br0配置文件
TYPE="Bridge"
BOOTPROTO="static"
DEVICE="br0"
ONBOOT="yes"
IPADDR=192.168.12.11
NETMASK=255.255.255.0
GATEWAY=192.168.12.2
[root@kvm-server ~]# systemctl restart network                      #重启网络服务
[root@kvm-server ~]# ifconfig                                       #查看IP是否在br0之上
br0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.12.11  netmask 255.255.255.0  broadcast 192.168.12.255
        inet6 fe80::20c:29ff:fe47:9adf  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:47:9a:df  txqueuelen 0  (Ethernet)
        RX packets 164  bytes 14690 (14.3 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 135  bytes 16092 (15.7 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        ether 00:0c:29:47:9a:df  txqueuelen 1000  (Ethernet)
        RX packets 99108  bytes 141414905 (134.8 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 39704  bytes 3796748 (3.6 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 0  (Local Loopback)
        RX packets 133  bytes 7864 (7.6 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 133  bytes 7864 (7.6 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:54:00:8d:eb:7b  txqueuelen 0  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

[root@kvm-server ~]# route -n                                        #查看路由表
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         192.168.12.2    0.0.0.0         UG    0      0        0 br0
169.254.0.0     0.0.0.0         255.255.0.0     U     1005   0        0 br0
192.168.12.0    0.0.0.0         255.255.255.0   U     0      0        0 br0
192.168.122.0   0.0.0.0         255.255.255.0   U     0      0        0 virbr0
[root@kvm-server ~]# brctl show                                      #查看br0桥接网络
bridge name    bridge id        STP enabled    interfaces
br0        8000.000c29479adf    no        eth0
virbr0        8000.5254008deb7b    yes        virbr0-nic



十、安装virt-manager图形化管理工具



[root@kvm-server ~]# yum install gnome-classic-session gnome-terminal nautilus-open-terminal control-center liberation-mono-fonts -y      #安装图形化界面
[root@kvm-server ~]# yum install virt-manager tigervnc tigervnc-server libguestfs-tools -y      #安装virt-manager图形化管理工具、vnc连接工具、磁盘管理工具
[root@kvm-server ~]# vncserver 

You will require a password to access your desktops.

Password:                                                                                       #设置连接VNC的密码
Verify:
Would you like to enter a view-only password (y/n)? y
Password:
Verify:
xauth:  file /root/.Xauthority does not exist
xauth: (stdin):1:  bad display name "kvm-server:1" in "add" command

New 'kvm-server:1 (root)' desktop is kvm-server:1

Creating default startup script /root/.vnc/xstartup
Creating default config /root/.vnc/config
Starting applications specified in /root/.vnc/xstartup
Log file is /root/.vnc/kvm-server:1.log
[root@kvm-server ~]# netstat -lntp | grep vnc                                                   #5901为VNC服务所监听端口
  tcp 0 0 0.0.0.0:5901 0.0.0.0:* LISTEN 2216/Xvnc 
  tcp 0 0 0.0.0.0:6001 0.0.0.0:* LISTEN 2216/Xvnc 
  tcp6 0 0 :::5901 :::* LISTEN 2216/Xvnc 
  tcp6 0 0 :::6001 :::* LISTEN 2216/Xvnc


十一、VNC客户端连接

支持kvm的安卓内核 kvm版本和内核版本_CentOS_03

支持kvm的安卓内核 kvm版本和内核版本_网络_04

十二、创建第一台虚拟机



[root@kvm-server ~]# qemu-img create -f raw /opt/CentOS-7.2-x86_64.raw 40G
Formatting '/opt/CentOS-7.2-x86_64.raw', fmt=raw size=42949672960 
[root@kvm-server ~]# virt-install --name CentOS-7.2-x86_64 --virt-type kvm --ram 1024 --cdrom=/opt/CentOS-7.2-x86_64-DVD-1511.iso --disk path=/opt/CentOS-7.2-x86_64.raw --network=default --graphics vnc,listen=0.0.0.0 --noautoconsole
[root@kvm-server ~]# netstat -lntp | grep qemu-kvm
tcp        0      0 0.0.0.0:5900            0.0.0.0:*               LISTEN      3232/qemu-kvm



 端口默认是从5900开始的,60s以内进行连接。

支持kvm的安卓内核 kvm版本和内核版本_网络_05

十三、虚拟机的管理可以使用virt-manager,直接在vnc界面运行virt-manager命令即可。

支持kvm的安卓内核 kvm版本和内核版本_CentOS_06

支持kvm的安卓内核 kvm版本和内核版本_嵌入式_07

 

支持kvm的安卓内核 kvm版本和内核版本_CentOS_08

 总结

此方法适用于KVM服务器和虚拟机同在一个网段的环境下。