基于KVM建立虚拟机的步骤及总结说明

时间:2021-01-16 07:26:38

1、前言

目前正在涉足云计算IaaS工作,虚拟化是IaaS的重要部分,因此这段时间对各个虚拟机化技术和工具进行研究,研究的目的不仅仅是为了会使用这个工具,而是通过研究了解技术的实现机制和原理,即知其然也要知其所以然,本文主要算是本人进入这个技术领域的入门的开始,在记录自己的进展的同时,希望对有类似追求的同仁有所帮助。为了更明晰各个步骤,安装步骤不采用图形方式。

KVM(不是键盘、显示器、鼠标)是一个基于Linux内核的虚拟化工具,具体的原理正在研究。

闲话少说,言归正传:

2、试验环境

硬件:Dell PowerEdge 2CPU 8G MEM

操作系统:Centos 5.5

hypervisor:kvm(Kenerl-based virtulization machine)

3、安装步骤

3.1 操作系统安装

这个步骤就不多说了,需要注意的是在安装过程中,选择定制功能,在Virtualization下选择kvm,因为在centos5.5下,虚拟化默认支持xen,安装完成后,建立虚拟化所需要的包如kvm、kvm-qemu、libvirt、Python等,会自动安装。

安装完成后,可以使用virsh命令检查一下虚拟化环境是否正常,具体命令如下:

virsh -c qemu:///system list

如果显示一个空列表,说明运行正常。

注:virsh命令是libvirt库提供的一个命令行工具,可以用来管理虚拟机。libvirt是什么?呵呵,这个可是个重要的东东,我将专门用一篇文章进行说明。

3.2 网络配置

操作系统安装完成支持虚拟化相关包后,会自动建立一个名称为virbr0的虚拟网桥,在多网卡情况下,此网桥默认与eth1网卡绑定。为了向虚拟机提供联网功能,KVM使用virbr0作为默认网络设备,因此在实际应用中,需要将virbr0与连接到实际网络的网卡绑定,例如我的是eth0。

具体方法是修改/etc/sysconfig/network-scripts目录下的网卡配置文件,如绑定etho,则修改ifcfg-eth0 和ifcfg-virbr0

修改后的配置文件内容如下:

1)ifcfg-eth0

DEVICE=eth0
      ONBOOT=yes
      BRIDGE=virbr0
      BOOTPROTO=dhcp
      TYPE=Ethernet

2)ifcfg-virbr0
      
      DEVICE=virbr0
      TYPE=Bridge 
      ONBOOT=yes
      DELAY=0
      BOOTPROTO=none
      IPADDR=10.100.0.3
      NETMASK=255.255.255.0
      GATEWAY=10.100.0.254

修改完成后,重新启动网络服务:service network restart
   默认的virbr0设置保存在/etc/libvirt/qemu/networks目录下,里面有一个default.xml文件,里面是virbr0的默认配置。

注:虚拟网桥由bridge-utils包中的brctl工具建立,这个包在安装虚拟化相关的包后自动安装, 使用brctl addbr 网桥名称可以增加网桥,使用brctl show显示已有网桥

3.3 建立虚拟机使用的文件

服务器上建立虚拟机的机制与在PC机上使用VMware Workstation、VirtualBox建立虚拟机类似,每个虚拟机均使用一个物理文件保存其安装的系统,模拟成磁盘,用来安装guest 操作系统,此文件可以先建好并格式化为一个专门的虚拟化文件格式(如qcow2),也可以在建立虚拟机的过程中指定,由虚拟机构建程序自动生成。

虚拟机使用的文件可以先以qemu-img命令先建好,也可以在通过使用virt-manager 、 virt-install建立虚拟机时建立,下面是使用qemu-img的语法:

qemu-img create -f qcow2 win7.img 20G     <---建立一个格式为qcow2、大小为20G的文件 
   
   建立完成后,显示:Formatting 'win7.img', fmt=qcow2, size=20971520 kB

   可以使用下面的命令检查文件格式:
   
A、file win7.img
Win7.img: x86 boot sector; partition 1: ID=0x7, active, starthead 32, startsector 2048, 204800 sectors; partition 2: ID=0x7, starthead 223, startsector 206848, 40751104 sectors
B、qemu-img info win7.img
      image: VM-Win7-1.img
      file format: raw
      virtual size: 20G (20971520000 bytes)
      disk size: 20G
备注:虚拟文件的格式有许多种,将在独立的文章中说明和分析。

3.4 建立虚拟机

完成上述的准备后,可以建立虚拟机了,这里使用virt-install命令完成本项工作。命令如下:

virt-install --name VM-Win7-2 \
                --hvm      \
                --ram 512  \
                --vcpus 2        \
                --disk path=/opt/images/win7.img,size=20 \
                --network network:default --accelerate \
                --vnc --vncport=5911 \
                --os-variant rhel5.4 \
                --cdrom /opt/ISO/windows7.iso -d
   
各个参数的意义如下 :
    
    --name   虚拟机名称
    --hvm     使用全虚拟化(与para-irtualization向对),如果在一个主机上para和full virtulization均可用,连接到没有硬件虚拟化支持的机器的xen hypervisor,这个 参数无效,这个参数意味着连接到基于qemu的hypervisor
    --ram     虚拟机内存大小
    --vcpus   虚拟机虚拟CPU个数
    --disk    虚拟机使用的磁盘(文件)的路径,本例中使用第3步中建立的文件,文件放置在/opt/images目录下
    --network 网络设置,使用默认设置即可,默认设置为使用第1步中说明的virbr0网桥
    --vnc     设置连接桌面环境的vnc端口,本例是5911
    --os-variant  指示为一个特定的操作系统变体(或版本)进一步优化客户机(guest)配置
    --cdrom   设置光驱获取虚拟光驱文件的路径 -d 指示从光驱启动( -c 指示从硬盘启动)

上面命令执行后,显示一连串提示,主要是建立虚拟机的进度和根据命令参数形成的虚拟机配置,虚拟机配置文件用xml文件存储,通过查看这个过程,能够对建立虚拟机过程有个比较直观的了解,下面是上述命令的的输出:

Thu, 17 Nov 2011 18:19:49 DEBUG    Requesting libvirt URI default              说明:请求连接默认URI,基于kvm hypervisor URI为 qemu:///system
Thu, 17 Nov 2011 18:19:49 DEBUG    Received libvirt URI 'qemu:///system'
Thu, 17 Nov 2011 18:19:49 DEBUG    Requesting virt method 'hvm' 说明:使用full虚拟化
Thu, 17 Nov 2011 18:19:49 DEBUG    Received virt method 'hvm'
Thu, 17 Nov 2011 18:19:49 DEBUG    Hypervisor name is 'kvm'
Thu, 17 Nov 2011 18:19:49 DEBUG    parse_disk: returning ('/opt/images/win7.img', None, None, 'disk', None, False, False, 20.0, True, None)
Thu, 17 Nov 2011 18:19:49 DEBUG    Setting os type to 'linux' for variant 'rhel5.4' 说明:设置基于rhel linux变体进行优化
Thu, 17 Nov 2011 18:19:49 DEBUG    DistroInstaller location is a local file/path: /opt/ISO/windows7.iso
Thu, 17 Nov 2011 18:19:49 DEBUG    Setting size for existing storage to '2.38835525513'
Thu, 17 Nov 2011 18:19:49 DEBUG    Detected storage as type 'file'     
     
Starting install...
Thu, 17 Nov 2011 18:19:49 DEBUG    Setting size for existing storage to '2.38835525513'
Thu, 17 Nov 2011 18:19:49 DEBUG    Detected storage as type 'file'
Creating storage file...                                                                                                                        |  20 GB     00:00    
    Thu, 17 Nov 2011 18:19:49 DEBUG    Creating guest from:
  
      <domain type='kvm'>                --说明:以下是虚拟机的配置文件,术语“domain”指虚拟机
        <name>VM-Win7-2</name>
        <currentMemory>524288</currentMemory>
        <memory>524288</memory>
        <uuid>8da64796-97aa-a6ae-5ecb-30a312139c19</uuid>
        <os>
          <type arch='x86_64'>hvm</type>
          <boot dev='cdrom'/>
        </os>
        <features>
          <acpi/><apic/><pae/>
        </features>
        <clock offset="utc"/>
        <on_poweroff>destroy</on_poweroff>
        <on_reboot>destroy</on_reboot>
        <on_crash>destroy</on_crash>
        <vcpu>2</vcpu>
        <devices>
          <emulator>/usr/libexec/qemu-kvm</emulator>
          <console type='pty'/>
          <disk type='file' device='disk'>
            <driver name='qemu' cache='none'/>
            <source file='/opt/images/win7.img'/>
            <target dev='vda' bus='virtio'/>
          </disk>
          <disk type='file' device='cdrom'>
            <source file='/opt/ISO/windows7.iso'/>
            <target dev='hdc' bus='ide'/>
            <readonly/>
          </disk>
          <interface type='network'>
            <source network='default'/>
            <mac address='54:52:00:1b:bc:d0'/>
            <model type='virtio'/>
          </interface>
          <input type='mouse' bus='ps2'/>
          <graphics type='vnc' port='5911' keymap='en-us'/>
        </devices>
      </domain>
     
      Creating domain...                                                                                                                              |    0 B     00:01    
      Thu, 17 Nov 2011 18:19:50 DEBUG    Created guest, looking to see if it is running 说明:建立完成guest,查看其是否正在运行
      Thu, 17 Nov 2011 18:19:50 DEBUG    Launching console callback
      Thu, 17 Nov 2011 18:19:50 DEBUG    Saving XML boot config:
      <domain type='kvm'>
        <name>VM-Win7-2</name>
        <currentMemory>524288</currentMemory>
        <memory>524288</memory>
        <uuid>8da64796-97aa-a6ae-5ecb-30a312139c19</uuid>
        <os>
          <type arch='x86_64'>hvm</type>
          <boot dev='hd'/>
        </os>
        <features>
          <acpi/><apic/><pae/>
        </features>
        <clock offset="utc"/>
        <on_poweroff>destroy</on_poweroff>
        <on_reboot>restart</on_reboot>
        <on_crash>restart</on_crash>
        <vcpu>2</vcpu>
        <devices>
          <emulator>/usr/libexec/qemu-kvm</emulator>
          <console type='pty'/>
          <disk type='file' device='disk'>
            <driver name='qemu' cache='none'/>
            <source file='/opt/images/win7.img'/>
            <target dev='vda' bus='virtio'/>
          </disk>
          <disk type='file' device='cdrom'>
            <target dev='hdc' bus='ide'/>
            <readonly/>
          </disk>
          <interface type='network'>
            <source network='default'/>
            <mac address='54:52:00:1b:bc:d0'/>
            <model type='virtio'/>
          </interface>
          <input type='mouse' bus='ps2'/>
          <graphics type='vnc' port='5911' keymap='en-us'/>
        </devices>
      </domain>
     
     
      (virt-viewer:10164): Gtk-WARNING **: cannot open display: 
      Thu, 17 Nov 2011 18:19:53 DEBUG    Domain state after install: 1
      Domain installation still in progress. You can reconnect to
      the console to complete the installation process.      

后面的错误指示virt-viewer 不能通过 5911连接vnc,这与vnc的设置有关,但是这不影响虚拟机继续安装操作系统和运行,通过这个错误可以看到virt-install在生产虚拟机的最后调用virt-viewer打开虚拟机图形界面,进行操作系统的安装,可以通过vnc或者virt-manager打开虚拟机图形界面,继续完成guest操作系统的安装即可,vnc可以安装realVNC。

通过vnc客户端或者virt-manager连接到新建立的虚拟机,继续进行虚拟机内操作系统的安装,安装过程与在物理机上安装相同,不在赘述。安装完操作系统后,就像拥有了另一台机器一样,通过VNC远程连接(如果装的是Windows操作系统,也可以使用RDP进行连接,就windows那个远程桌面连接)可以进行相关操作了。

4、总结

在配置虚拟机的过程中

1)上述工作,在virt-manager中可以通过图形向导界面也可以完成,virt-manager可以通过在终端中输入virt-manager或者从菜单应用程序->系统工具中打开

2)使用qemu-kvm 命令也可以建立虚拟机【libvirt api中应该也提供了类似的函数,openstack、eucalyptus之类的虚拟机管理(也称为云计算管理)工具调用这个函数建立虚拟机】

命令如下:
        qemu-kvm -m 1024 -localtime -M pc -smp 1 -drive file=/opt/images/Win7.img,cache=writeback,boot=on -net nic,macaddr=52:54:00:12:34:80 -net tap -cdrom /opt/ISO/Windows7.iso -boot d -name win7,process=kvm-win7 -vnc :2 -usb -usbdevice tablet

参数说明如下:
              -m 1024  设置虚拟系统内存1024MB
              -localtime  使虚拟系统与宿主系统时间一致
              -M pc  虚拟系统类型为pc
              -smp 1  1个CPU
              -drive file=Windows7_x86.img,cache=writeback,boot=on
                     硬盘选项,虚拟磁盘是Windows7_x86.img,cache方式为writeback,可引导型磁盘。
              -net nic,macaddr=52:54:00:12:34:80  网卡选项,手工指定mac地址。
              -net tap  tap类型网络,相当于“桥模式”
              -cdrom Windows7.iso  光驱
              -boot d  启动顺序。d代表光驱。
              -name kvm-win7,process=kvm-win7  为虚拟机取名,便于识别
              -vnc :2  这里是通过vnc连接控制窗口,这里是在5902端口。
              -usb -usbdevice tablet  启用usb设备中的tablet功能。开启该功能可使虚拟机内外的鼠标同步

参数与virt-install基本相同。
 
        在安装了磁盘和网卡的半虚拟化驱动后,可以在-drive中加入if=virtio使用磁盘半虚拟化,在-net nic中加入model=virtio使用网卡半虚拟化驱动。virio在kenerl 2.6.24以上版本才能更好的发挥效用。

3)其实无论用哪种方法建立的基于kvm的虚拟机,都由qemu-kvm进行启动和管理,下面是查看liunx进程显示的一个虚拟机进程:

qemu-kvm -S -M rhel5.4.0 -m 1024 -smp 2 -name VM-win7 -uuid 71c4020b-ca54-20f2-780c-ec9fa070aa84 -no-kvm-pit-reinjection -monitor pty -pidfile /var/run/libvirt/qemu//VM-ubuntu-1104.pid -boot c -drive file=/opt/images/ubuntu-11.04-desktp.img,if=virtio,index=0,boot=on,cache=none -drive file=,if=ide,media=cdrom,index=2 -net nic,macaddr=54:52:00:0a:55:05,vlan=0,model=virtio -net tap,fd=17,script=,vlan=0,ifname=vnet0 -serial pty -parallel none -usb -vnc 0.0.0.0:11 -k en-us

一个虚拟机占用一个进程,可以通过进程管理和控制虚拟机。

4)虚拟机个相关配置保存在一个配置文件中,因此可以手工可以编写一个配置文件,然后通过virsh命令行构建虚拟机,已建好的虚拟机,配置文件更改后,需要用virsh define重新定义后才能生效。

5)基于KVM建立的虚拟机相关文件默认存放位置
         kvm虚拟机配置文件位置/etc/libvirt/qemu/      <---都是xml文件
         kvm虚拟机文件位置:var/lib/libvirt/images/   <---可以在建立虚拟机时指定

6)建立的虚拟机在运行时相关文件及存放位置
        在虚拟机运行时,会在/var/run/libvirt/qemu目录下存放虚拟机的pid文件和配置文件,配置文件与/etc/libvirt/qemu目录下对应的虚拟机文件相同,pid文件保存有此虚拟机进程号。虚拟机的日志文件存放在/var/log/libvirt/qemu目录下,每个虚拟机一个,文件名称为:虚拟机名称(或UUID)+“.log”

7)qemu不使用linux下的vncserver提供vnc服务,因此在此服务没有启动的情况下,也能通过vnc客户端连接到虚拟机。

通过上面的配置验证,说明在服务器上的虚拟化与桌面上的虚拟化在原来上基本相同,都是通过相关配置构建一个虚拟机,这个虚拟机的各类外设如磁盘、内存、CPU、网卡等通过都是对物理资源虚拟而获得,形成一个逻辑上的计算机,并通过一个文件进行保存。区别是桌面上的虚拟化采用的是软件模拟,服务器上则实现机制很多,由不依赖与操作系统(bare metal)的VMware ESX、Microsoft Hyper-V,也有与操作系统集成的kvm,还有同时提供bare metal机制,又需要一个操作系统对虚拟机进行管理的xen等,这些东西都称之为hypervisor。其实对于用户来说都是透明的,他们不需要知道其使用的虚拟机是采用何种方式实现的。

http://blog.csdn.net/starshine/article/details/6990599