一直在研究kvm的para-virtualization driver - virtio,可能是太熟的原因吧,今天突然发现不知道咋在libvirt层配置kvm采用virtio驱动了,问题在于,看到下面这个配置文件,我竟不能确定此配置是否是采用了virtio驱动,先来看下配置文件的virtio相关的部分:

  1. <disk type='file' device='disk'>
  2.     <source file='/data0/0/21/disk.0'/>
  3.     <target dev='vda'/>
  4.     <driver name='qemu' type='qcow2' cache='default'/>
  5. </disk>


     于是,我就google一个网上的采用virtio驱动的配置文件:

  1. <disk type='file' device='disk'>
  2.             <driver name='qemu' cache='none'/>
  3.             <source file='/opt/images/win7.img'/>
  4.             <target dev='vda' bus='virtio'/>
  5.           </disk>
    然后,问题就更多了:

   (1)是不是在target item中增加bus='virtio'就说明采用了virtio驱动

   (2)google的这个例子的image文件win7.img是什么格式的,我的例子可以从driver item的type参数看出是qcow2,google的例子怎么看出来?(可能有人会说,可以通过file命令来查看),但是这并不符合我的风格,写个配置文件必须能解决所有疑问才行,要file下才知道啥意思,那只能说这个配置文件写的太失败了。

    带着以上问题,我阅读了下libvirt documents,下了如下总结。

1. 配置项说明

    disk常用的配置参数:type,device,snapshot等

(1)type属性可以设置为:file,block,dir,network等值,这主要取决于底层的实现

(2)device属性用来表示Guest OS看来,disk表现为什么类型的设备,其值为:floppy,disk,cdrom,lun等,默认值为disk

(3)snapshot属性用来描述与磁盘快照相关的功能时的一些默认的行为:

  • snapshot='internal',表示snapshot与data存储在同一个文件中,比如一个qcow2文件,即镜像和数据是一体的,没有单独的snapshot文件
  • snapshot='external',表示镜像文件和data分离存储,即有单独的snapshot文件
  • snapshot='no',表示禁止disk的snapshot的功能

      read-only的disk不支持快照的功能,另外,这些属性是否生效还要取决于hypervisor。

2. 说明

   source常用的配置参数:dev,file,dir,protocol等,如果disk的type='file',那么source的file属性指向image文件的完整路径;如果disk的type='block',那么source的dev属性指向host上的某个设备,如/dev/sdb;如果disk的type='dir',那么source的dir指向host上的某一个目录,此目录用来做vm的镜像;如果disk的type='network',那么source的protocol参数,该参数用来指定访问remote image的协议,其值可以为:nbd,rbd,sheepdog或gluster,此时,另外一个mandatory属性必须设置为remote端的哪一个volume/image将被使用

(1)file attribute

  1. <disk type='file' device='disk'>
  2.             <driver name='qemu' type='qcow2'/>
  3.             <source file='/data2/vms/ubuntu.qcow2'/>
  4.             <target dev='vda' bus='virtio'/>
  5.         </disk>

(2)dev attribute

  1. <disk type='block' device='lun'>
  2.       <driver name='qemu' type='raw'/>
  3.       <source dev='/dev/sda'/>
  4.       <target dev='sda' bus='scsi'/>
  5.       <address type='drive' controller='0' bus='0' target='3' unit='0'/>
  6.     </disk>

(3)dir attribute (use a directory as floppy)

  1. <disk type='dir' device='floppy'>
  2.           <source dir='/tmp/test'/>
  3.           <target dev='fda' bus='fdc'/>
  4.           <readonly/>
  5.         </disk>

(4)protocol attribute

  1. <disk type='network'>
  2.       <driver name="qemu" type="raw" io="threads" ioeventfd="on" event_idx="off"/>
  3.       <source protocol="sheepdog" name="image_name">
  4.         <host name="hostname" port="7000"/>
  5.       </source>
  6.       <target dev="hdb" bus="ide"/>
  7.       <boot order='1'/>
  8.       <transient/>
  9.       <address type='drive' controller='0' bus='1' unit='0'/>
  10.     </disk>

3. 说明

   target item用来说明disk所挂载的总线的类型,此总线是guest os中看到的总线类型,比如从guest os中看到的硬盘是ide还是scsi的,这取决于设备挂载的总线。 target常用的attribute有:dev和bus.

(1) dev attribute

  disk设备的logical name,比方说:hdx,sdx,vdx等

(2) bus attribute

  此用来描述仿真的设备的类型,其值可以为:ide,scsi,virtio,xen,usb,sata等,此attribute value可以通过dev的value来推断 出来,如果dev='hdb',那么bus='ide';如果dev='vda',那么bus='virtio'

4. 说明

  this item更详细的描述了hypervisor为disk提供的driver,其common used attribute包括:name,type,cache等

(1)name attribute

    对于kvm来说,name has an unique value - 'qemu',xen可以支持很多值,不错详细介绍。

(2)type attribute

   kvm支持raw,qcow2,qed,bochs等多种镜像格式,不同的镜像格式对应着不同的驱动类型。另外,kvm是目前支持的镜像格式最全的一种hypervisor。

(3)cache attribute

   cache控制着guest os对disk的cache机制,cache的方式有:default,none,writethrough,writeback,directsync,unsafe等,cache的类型影响着guest os的性能,所以需要根据实际应用场景来选择,比较常用的类型为:none,writethrough,writeback.

   至于三种cache的区别和原理,请参见《kvm 存储栈分析 》一文!

   至此,virtio的问题已经解决!感觉以后必须随时做好笔记,加深对某些问题的理解,要不然时间已久就全忘了。

   在下面的文章中将会详细的分析virtio驱动框架及其原理,希望有兴趣的同学一起讨论学习!


09-26 09:36