StratoVirt中MicroVM启动过程
0x01 microvm vs 标准vm
1.1 什么是MicroVM微虚拟机?
微虚拟机正是相对于标准虚拟机而言的。标准虚拟机是模拟真正的物理主机,乃至PC,所以它会拥有完整的外设(键盘、USB、串口、PCI设备、显示器等)。在云原生技术兴起之前,AWS已经在布局FaaS(函数即服务),也即serverless业务,AWS为了实现强隔离不同的函数实例,同时支持快速、低消耗启动多个实例,推出了Firecracker的微虚拟机技术。
microvm与传统的Qemu/KVM虚拟机的区别是,它只实现了用于服务端计算服务所需要的最小硬件集。按照文章[https://aws.amazon.com/cn/blogs/china/in-depth-analysis-of-aws-firecracker/]中所描述的,Firecracker只实现了虚拟网络、虚拟磁盘和虚拟sock、串口、和单个键的键盘。Firecracker的MicroVM可以在微秒级别内启动,而且内存底躁小于5MB(虚拟机运行时的需要总内存减去虚拟机配置内存)。以上两个参数都是传统虚拟机不能比拟的。
1.2 MicroVM为什么启动快?
传统虚拟机的外设比较多,外设在启动时都需要内核的处理,如加载驱动、硬件初始化等;存在多个网卡时,还需要为每个网卡配置网络;虚拟机内的操作系统没有经过专门处理,所以要启动很多服务。而MicroVM直接定制了虚拟机内核(Linux),最少的外设,抛弃传统的BIOS加载启动过程,所以它可以快速启动。
与Firecracker对应的国内项目就是openEuler社区的Stratovirt项目了。除了支持MicroVM,Stratovirt还支持标准虚拟机。对其系统的介绍见Rust社区文章 华为 | 基于Rust的下一代虚拟化平台-StratoVirt
下面跟随实例去探索下MicroVM启动过程,领略下其实现过程。
0x02 Stratovirt中MicroVM的启动过程
如下,我们按照文档中描述的步骤启动一个openEuler的MicroVM。<