一、KVM安装

1、安装前准备

环境准备

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

禁用Selinux,禁用防火墙

接下来,开始安装

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

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

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

我这里用的是虚拟机,在处理器配置页面,选择了“虚拟化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 ~]# ifconfigeth0: 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 0lo: 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 0virbr0: 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 dnsnobody     2529      1  0 Sep04 ?        00:00:00 /sbin/dnsmasq --conf-file=/var/lib/libvirt/dnsmasq/default.conf --leasefile-ro --dhcp-script=/usr/libexec/libvirt_leaseshelperroot       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-imgqemu-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-installvirt-install: /usr/bin/virt-install /usr/share/man/man1/virt-install.1.gz[root@linux-node1 ~]# cat /usr/bin/virt-install #!/bin/shexec "/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 tothe console to complete the installation process.

查看系统的端口占用情况

netstat -lntp|grep 5900vnc的端口是从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 offvirsh list --all  #显示本地所有的虚拟机(活动的+不活动的)virsh list        #显示本地活动虚拟机

启动虚拟机

[root@linux-node1 ~]# virsh start CentOS-7-x86_64Domain 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=EthernetBOOTPROTO=dhcpDEFROUTE=yesPEERDNS=noPEERROUTES=yesIPV4_FAILURE_FATAL=no#IPV6INIT=yes#IPV6_AUTOCONF=yes#IPV6_DEFROUTE=yes#IPV6_PEERDNS=yes#IPV6_PEERROUTES=yes#IPV6_FAILURE_FATAL=noNAME=eth0#UUID=b662ea05-2764-49e2-9eba-94c4fff38456DEVICE=eth0ONBOOT=yes
[root@localhost ~]# ip ad li1: 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 forever2: 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 forever3: 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 forever4: 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-toolsyum 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 kvmroot        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=onroot      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可以管理的虚拟化:XenKVMVMwareVirtualBoxHyper-V

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

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

2、libvirt管理虚拟机

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

[root@linux-node1 /etc/libvirt/qemu]# lltotal 4-rw------- 1 root root 3886 Sep  4 02:51 CentOS-7-x86_64.xmldrwx------ 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 BEOVERWRITTEN AND LOST. Changes to this xml configuration should be made using:  virsh edit CentOS-7-x86_64or 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]# lsbackup.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_64
4把原来文件中的static改成auto,添加current="1",再把原来值由1改为4
4

修改后,重启客户机

virsh shutdown CentOS-7-x86_64virsh 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查看是否与修改的一致。

扩容有风险,操作需谨慎