“常通风、勤洗手、戴口罩、少出门。”
“武汉加油、中国加油!”
喻津, 资深工程师, 主要从事SPDK的软件开发工作。
背景
在All in Cloud的趋势下,各大CSPs(Cloud Service Providers)在宣传自家的服务时都会向客户声称提供高可靠,高稳定的服务例如5个9的可用性(99.999%)。但是,仅仅以后端存储举例,技术和产品的升级等等都不可避免的需要他们进行在线升级,并且这个行为要在短时间内完成,这样才能满足5个9的标准。
Virtio是目前被广泛接受的I/O虚拟化的抽象设备接口,通过对virtqueue的定义实现了对不同虚拟化PCI设备的支持,广泛的运用在VM(Virtual Machine)中用来加速包括存储和网络等设备。Vhost是一种用来加速Guest到后端传输的软件解决方案,它基于virtio实现。然而查看已有的解决办法,并没有发现一种很好的支持在线升级的方法。
基于此,本文将介绍SPDK Vhost提供的一种方法,可以灵活,快速的实现在线升级。
Virto和Vhost的简单介绍
Virtio由OASIS[1](Advancing Open Standard For Information Society)定义,它是半虚拟化协议规范,规定Guest OS和Hypervisor通过定义的队列结构进行数据面通信,本文中的Hypervisor我们都使用QEMU来进行说明,这个队列在Virtio S