一、KVM安装

1、安装前准备

环境准备

IP			主机名			操作系统
192.168.56.11		linux-node1		centos7

禁用Selinux,禁用防火墙

接下来,开始安装

(1)首先查看是否支持虚拟化

[root@linux-node1 ~]# grep -E -o 'svm|vmx' /proc/cpuinfo 
vmx
vmx
vmx
vmx

有结果,说明支持虚拟化。

我这里用的是虚拟机,在处理器配置页面,选择了“虚拟化Intel VT-x/EPT或AMD-V/RVI(V)”,支持虚拟化。

如果是物理机,而且执行执行上面的命令没有返回结果,那么就得去BIOS中找Virtualization Technology或者VT关键字,设置为enabled或on。

(2)安装KVM

yum -y install qemu-kvm qemu-kvm-tools libvirt

安装完后,启动libvirt

systemctl start libvirtd    

systemctl enable libvirtd     #设置开机启动

libvirtd用来管理kvm

启动libvirtd后,执行ifconfig

[root@linux-node1 ~]# ifconfig
eth0: flags=4163mtu 1500
        inet 192.168.56.11  netmask 255.255.255.0  broadcast 192.168.56.255
        inet6 fe80::20c:29ff:fe83:fcc2  prefixlen 64  scopeid 0x20
        ether 00:0c:29:83:fc:c2  txqueuelen 1000  (Ethernet)
        RX packets 411241  bytes 334142719 (318.6 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 431982  bytes 449719632 (428.8 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10loop  txqueuelen 0  (Local Loopback)
        RX packets 252754  bytes 20684384 (19.7 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 252754  bytes 20684384 (19.7 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

virbr0: flags=4099mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:54:00:c5:ce:47  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

自动创建了一个virbr0网卡,地址是192.168.122.1,这是安装kvm时都会创建的。

执行ps aux|grep dns

[root@linux-node1 ~]# ps -ef|grep dns
nobody     2529      1  0 Sep04 ?        00:00:00 /sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/libexec/libvirt_leaseshelper
root       2530   2529  0 Sep04 ?        00:00:00 /sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/libexec/libvirt_leaseshelper

libvirt启动了一个dnsmasq进程,这个进程有dns和dhcp的功能,帮助我们分配地址。

二、使用KVM安装虚拟机

1、安装前准备

(1)准备虚拟机硬盘

qemu-img命令用于创建虚拟硬盘

[root@linux-node1 ~]# whereis qemu-img
qemu-img: /usr/bin/qemu-img /usr/share/man/man1/qemu-img.1.gz
[root@linux-node1 ~]# rpm -qf /usr/bin/qemu-img 
qemu-img-1.5.3-105.el7_2.7.x86_64

rpm -qf用于查看一个已经安装的文件属于哪个软件包

qemu-img create -f raw /opt/CentOS-7-x86_64.raw 10G

-f raw        是创建虚拟机磁盘的文件格式
/opt/CentOS-7-x86_64.raw   是文件名称
10G           是文件大小

(2)准备镜像

使用xftp往192.168.56.11主机里上传一个centos镜像

[root@linux-node1 /opt]# ll /opt/CentOS-7-x86_64-DVD-1511.iso 
-rw-r--r-- 1 qemu qemu 4329570304 Sep  4 01:55 /opt/CentOS-7-x86_64-DVD-1511.iso

(3)使用virt-install工具安装虚拟机

virt-install其实就是一个python写的脚本 。它是qemu-kvm工具的人性化实现。可以利用该工具在终端下创建KVM guest主机。

直接用yum安装

yum -y install virt-install
[root@linux-node1 ~]# whereis virt-install
virt-install: /usr/bin/virt-install /usr/share/man/man1/virt-install.1.gz

[root@linux-node1 ~]# cat /usr/bin/virt-install 
#!/bin/sh

exec "/usr/share/virt-manager/virt-install" "$@"


[root@linux-node1 ~]# more /usr/share/virt-manager/virt-install
#!/usr/bin/python2 -tt
#
# Copyright 2005-2014 Red Hat, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.

安装kvm guest主机

virt-install --virt-type kvm --name CentOS-7-x86_64 --ram 2048 --cdrom=/opt/CentOS-7-x86_64-DVD-1511.iso --disk path=/opt/CentOS-7-x86_64.raw --network=default --graphics vnc,listen=0.0.0.0 --noautoconsole

--virt-type kvm      #虚拟机类型是kvm
--name               #虚拟机名称
--ram                #内存
--cdrom              #磁盘镜像
--disk               #虚拟磁盘路径
--network            #默认是default,虚拟机装好后,用此网段的地址
--graphics           #使用的图形界面
--noautoconsole      #使用本选项指定不自动试图连接到客户机控制台

执行完成后,会有如下提示

Starting install...
Creating domain...
Domain installation still in progress.You can reconnect to
the console to complete the installation process.

查看系统的端口占用情况

netstat -lntp|grep 5900

vnc的端口是从5900开始的。使用vnc连接时,默认不用输入端口号

使用vnc连接后,进入CentOS7的安装界面

CentOS7安装时,默认的网卡名称不是eth0,为了标准化,在安装之前,先修改网卡名称。进入安装界面后,敲击tab键,来进行修改

在vmlinuz initrd=initrd.img......语句后面添加
net.ifnames=0 biosdevname=0

往下的步骤就是安装操作系统,选择时区、语言、密码、软件最小安装、分区等等,这些步骤可以在网上查到,不再详述。

安装完后点击reboot

注意: 注意: 注意:新安装的虚拟机它是无法启动的。

(4)使用virt工具管理虚拟机

显示虚拟机

[root@linux-node1 ~]# virsh list --all
 Id    Name                           State
----------------------------------------------------
 -     CentOS-7-x86_64                shut off


virsh list --all  #显示本地所有的虚拟机(活动的+不活动的)
virsh list        #显示本地活动虚拟机

启动虚拟机

[root@linux-node1 ~]# virsh start CentOS-7-x86_64
Domain CentOS-7-x86_64 started


[root@linux-node1 ~]# virsh list --all
 Id    Name                           State
----------------------------------------------------
 2     CentOS-7-x86_64                running

再次使用TightVNC连接虚拟机,这时可以连接。

由于是最小化安装,所以很多软件包都没有安装,先配置网卡,调通网络,进行yum安装。

(5)配置虚拟机网卡

配置网卡

[root@localhost ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0 
TYPE=Ethernet
BOOTPROTO=dhcp
DEFROUTE=yes
PEERDNS=no
PEERROUTES=yes
IPV4_FAILURE_FATAL=no
#IPV6INIT=yes
#IPV6_AUTOCONF=yes
#IPV6_DEFROUTE=yes
#IPV6_PEERDNS=yes
#IPV6_PEERROUTES=yes
#IPV6_FAILURE_FATAL=no
NAME=eth0
#UUID=b662ea05-2764-49e2-9eba-94c4fff38456
DEVICE=eth0
ONBOOT=yes
[root@localhost ~]# ip ad li
1: lo:mtu 65536 qdisc noqueue state UNKNOWN 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: eth0:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 52:54:00:45:2f:9d brd ff:ff:ff:ff:ff:ff
    inet 192.168.122.22/24 brd 192.168.122.255 scope global dynamic eth0
       valid_lft 2920sec preferred_lft 2920sec
    inet6 fe80::5054:ff:fe45:2f9d/64 scope link 
       valid_lft forever preferred_lft forever
3: virbr0:mtu 1500 qdisc noqueue state DOWN 
    link/ether 00:00:00:00:00:00 brd ff:ff:ff:ff:ff:ff
    inet 192.168.124.1/24 brd 192.168.124.255 scope global virbr0
       valid_lft forever preferred_lft forever
4: virbr0-nic:mtu 1500 qdisc pfifo_fast state DOWN qlen 500
    link/ether 52:54:00:13:0d:2e brd ff:ff:ff:ff:ff:ff
[root@localhost ~]#

这样就可以yum安装软件了

yum install net-tools

yum install vim screen mtr nc nmap tree lrzsz openssl-devel gcc glibc gcc-c++ make zip dos2unix systat

(6)进程分析

[root@linux-node1 ~]# ps -ef|grep kvm
root        844      2  0 Sep04 ?        00:00:00 [kvm-irqfd-clean]
qemu      17214      1 12 14:58 ?        00:02:13 /usr/libexec/qemu-kvm -name CentOS-7-x86_64 -S -machine pc-i440fx-rhel7.0.0,accel=kvm,usb=off -cpu Nehalem -m 2048 -realtime mlock=off -smp 1,sockets=1,cores=1,threads=1 -uuid 317f5d1e-6fd1-47f3-bb86-fa4505d3ef30 -no-user-config -nodefaults -chardev socket,id=charmonitor,path=/var/lib/libvirt/qemu/domain-CentOS-7-x86_64/monitor.sock,server,nowait -mon chardev=charmonitor,id=monitor,mode=control -rtc base=utc,driftfix=slew -global kvm-pit.lost_tick_policy=discard -no-hpet -no-shutdown -global PIIX4_PM.disable_s3=1 -global PIIX4_PM.disable_s4=1 -boot strict=on -device ich9-usb-ehci1,id=usb,bus=pci.0,addr=0x5.0x7 -device ich9-usb-uhci1,masterbus=usb.0,firstport=0,bus=pci.0,multifunction=on,addr=0x5 -device ich9-usb-uhci2,masterbus=usb.0,firstport=2,bus=pci.0,addr=0x5.0x1 -device ich9-usb-uhci3,masterbus=usb.0,firstport=4,bus=pci.0,addr=0x5.0x2 -device virtio-serial-pci,id=virtio-serial0,bus=pci.0,addr=0x4 -drive file=/opt/CentOS-7-x86_64.raw,if=none,id=drive-virtio-disk0,format=raw -device virtio-blk-pci,scsi=off,bus=pci.0,addr=0x6,drive=drive-virtio-disk0,id=virtio-disk0,bootindex=1 -drive if=none,id=drive-ide0-0-0,readonly=on,format=raw -device ide-cd,bus=ide.0,unit=0,drive=drive-ide0-0-0,id=ide0-0-0 -netdev tap,fd=23,id=hostnet0,vhost=on,vhostfd=24 -device virtio-net-pci,netdev=hostnet0,id=net0,mac=52:54:00:45:2f:9d,bus=pci.0,addr=0x3 -chardev pty,id=charserial0 -device isa-serial,chardev=charserial0,id=serial0 -chardev socket,id=charchannel0,path=/var/lib/libvirt/qemu/channel/target/domain-CentOS-7-x86_64/org.qemu.guest_agent.0,server,nowait -device virtserialport,bus=virtio-serial0.0,nr=1,chardev=charchannel0,id=channel0,name=org.qemu.guest_agent.0 -device usb-tablet,id=input0 -vnc 0.0.0.0:0 -vga cirrus -device virtio-balloon-pci,id=balloon0,bus=pci.0,addr=0x7 -msg timestamp=on
root      17219      2  0 14:58 ?        00:00:00 [kvm-pit/17214]
root      17593  17549  0 15:16 pts/3    00:00:00 grep --color=auto kvm

通过查看进程我们可以看到,我们启动的一个虚拟机,从宿主机的角度看,就是启动了一个进程,这个进程通过qemu用户启动。

如果我们kill掉这个进程,虚拟机就像断电一样,关机了。

三、虚拟化管理工具介绍

1、Libvirt介绍

libvirt可以管理的虚拟化:
Xen
KVM
VMware
VirtualBox
Hyper-V

libvirt需要后台启动一个libvirtd进程

如果停止了libvirtd进程,虚拟机仍然运行。这说明libvirtd进程停止后,虚拟机会独立运行,但不再受libvirt管理。

2、libvirt管理虚拟机

进入/etc/libvirt/qemu目录,我们可以看到一个xml文件

[root@linux-node1 /etc/libvirt/qemu]# ll
total 4
-rw------- 1 root root 3886 Sep  4 02:51 CentOS-7-x86_64.xml
drwx------ 3 root root   40 Sep  4 02:29 networks
[root@linux-node1 /etc/libvirt/qemu]#

libvirt是通过这个xml文件来管理虚拟机的

[root@linux-node1 /etc/libvirt/qemu]# vim CentOS-7-x86_64.xml 


WARNING: THIS IS AN AUTO-GENERATED FILE. CHANGES TO IT ARE LIKELY TO BE
OVERWRITTEN AND LOST. Changes to this xml configuration should be made using:
  virsh edit CentOS-7-x86_64
or other application using the libvirt API.
这段话是说,这个文件是自动生成的,而且不能更改。
如果想编辑,需要使用virsh edit CentOS-7-x86_64
或者调用libvirt API

3、virsh常用参数

当我们需要使用virsh来执行某个命令时,需要使用virsh --help来查看virsh提供哪些参数及功能。

备份xml文件

[root@linux-node1 /etc/libvirt/qemu]# virsh dumpxml CentOS-7-x86_64 > backup.xml
[root@linux-node1 /etc/libvirt/qemu]# ls
backup.xml  CentOS-7-x86_64.xml  networks

关闭虚拟机

virsh shutdown CentOS-7-x86_64

启动虚拟机

virsh start CentOS-7-x86_64

挂起虚拟机

virsh suspend CentOS-7-x86_64

恢复虚拟机

virsh resume CentOS-7-x86_64

创建快照

virsh snapshot-create CentOS-7-x86_64

注意:raw格式不支持创建快照

virsh snapshot-list  #查看快照

以上可以对比vmware workstation的功能

4、虚拟机调优

(1)cpu调整

修改cpu数量

在使用virt-install安装虚拟机时就可以指定cpu个数

[root@linux-node1 ~]# virt-install --help|grep cpu
  --vcpus VCPUS         Number of vcpus to configure for your guest. Ex:
                        --vcpus 5
                        --vcpus 5,maxcpus=10,cpuset=1-4,6,8
                        --vcpus sockets=2,cores=4,threads=2,
  --cpu CPU             CPU model and features. Ex:
                        --cpu coreduo,+x2apic
                        --cpu host
使用--vcpus可以指定客户机cpu的个数
可以实现动态修改
但是不能超过cpu个数最大值

修改cpu个数

编辑xml文件
[root@linux-node1 /etc/libvirt/qemu]# virsh edit CentOS-7-x86_644把原来文件中的static改成auto,添加current="1",再把原来值由1改为4
4

修改后,重启客户机

virsh shutdown CentOS-7-x86_64
virsh start CentOS-7-x86_64

然后再执行如下命令即可

virsh setvcpus CentOS-7-x86_64 2 --live

(2)内存调整

修改

virsh qemu-monitor-command CentOS-7-x86_64 --hmp --cmd balloon 512

查看

virsh qemu-monitor-command CentOS-7-x86_64 --hmp --cmd info balloon

登录到客户机执行free -m查看是否与修改的一致。

扩容有风险,操作需谨慎