QEMU:模拟io的基本原理:
- 当客户机中的设备驱动程序发起一次Io操作时,kvm会拦截本次io操作,然后把io请求放到IO共享页中,并通知qemu程序,当qemu模拟结束io操作结果后在放到IO共享页,并通知kvm中IO操作捕获代码;
- qemu模拟IO的优点是,可以模拟任何设备的,而且不用修改客户机参数,缺点是时间太久;
virtio的基本原理:
- 在virtio进行IO模拟时主要有三个地方,前段,后端,缓冲区,前段有虚拟机实现Io的操作,后端有qemu模拟IO,并且返回给前段,而缓冲区的作用是保存多次IO操作,一次返回个前段或者后端,这样有利于提高虚拟机的效率;优点是速度快,性能好,缺点是有的老机子不支持;
Balloon:
- 气球技术可以在客户机运行状态动态调整它所占的宿主内存资源,而不需要关闭客户机;
- 故名思议,把内存当成气球一样来使用,气球中的内存可以被宿主机使用,但是不能被客户机直接使用和访问,所以当宿主机缺少内存是,balloon释放掉一部分内存,给宿主机使用;相反当客户机内存不够时,客户机吹从宿主机获取内存;
- 优点:1因为balloon可以被监控,和控制,2而且balloon对内存的调度很灵活,
- 缺点:1,客户机需要加载该驱动,而且不是每个系统都有该驱动,(virtio_balloon)2,如果有大量的内存从客户系统回收,会降低系统的运行,3,目前没有比价方便,自动化管理balloon的机制,一般都采用qemu来管理,
客户机可以使用的设备大致分为三类:
- 1,qemu:纯软件模拟,
- 2,实现virtIo API,半虚拟化的设备
- 3,,直接分配设备
- 1,的优点是对硬件的平台依赖性低,兼容性高,但是性能比较差
- 2,比普通的IO模拟效率高,但是需要相关的virtIo驱动的支持,
- 3,允许将物理机上的设备直接给虚拟机用,缺点是,主板空间有限,而硬件的添加会加大成本
- 改进的办法是,在一台宿主机山只对io要求操作高的客户机使用直接分配设备的方法,其他客户机采用纯软件模拟的办法,或者是virtio的方法;