实验环境:
- VMware Workstation
- OS: Centos8.0 虚拟机
- Kernel: 4.18.0
- Arch: x86_64
StratoVirt简介
StratoVirt 是计算产业中面向云数据中心的企业级虚拟化平台,实现了一套架构统一支持虚拟机、容器、Serverless 三种场景。StratoVirt 在轻量低噪、软硬协同、Rust 语言级安全等方面具备关键技术竞争优势。
StratoVirt 在保留传统虚拟化的隔离能力和安全能力的同时,降低了内存资源消耗,提高了虚拟机的启动速度。StratoVirt 可应用于微服务或无服务器场景,如函数计算。
StratoVirt 预留了接口和设计来支持更多特性,未来甚至向标准虚拟化演进。
特性:
- 强安全性与隔离性
采用内存安全语言Rust编写, 保证语言级安全性;
基于硬件辅助虚拟化实现安全多租户隔离,并通过seccomp进一步约束非必要的系统调用,减小系统攻击面;
- 轻量低噪
轻量化场景下冷启动时间<50ms,内存底噪<4M;
- 高速稳定的IO能力
具有精简的设备模型,并提供了稳定高速的IO能力;
- 资源伸缩
具有ms级别的设备伸缩时延,为轻量化负载提供灵活的资源伸缩能力;
- 全场景支持
完美支持X86和Arm平台:X86支持VT,鲲鹏支持Kunpeng-V,实现多体系硬件加速;
可完美集成于容器生态,与Kubernetes生态完美对接,在虚拟机、容器和serverless场景有广阔的应用空间;
- 扩展性
架构设计完备,各个组件可灵活地配置和拆分;
设备模型可扩展,可扩展PCIe等复杂设备规范,实现标准虚拟机演进;
架构:
- OCI兼容接口:兼容qmp协议,具有完备的OCI兼容能力。
- BootLoader:抛弃传统的BIOS + GRUB启动模式, 实现了更轻更快的BootLoader,并达到极限启动时延。
- MicroVM:充分利用软硬协同能力;精简化设备模型;低时延资源伸缩能力;
VMware Workstation开启嵌套虚拟化
下载并编译StratoVirt
1 2 3
| # git clone https://gitee.com/openeuler/stratovirt.git # cd stratovirt # cargo build --release
|
准备kernel及initrd
1 2 3
| # dd if=/boot/vmlinuz-4.18.0-80.el8.x86_64 bs=1 skip=0018353 | zcat > vmlinux # 解压出 vmlinux # objcopy -O binary vmlinux vmlinux.bin # cp /boot/initramfs-4.18.0-80.el8.x86_64.img initramfs.img
|
解压vmlinux skip=0018353
参数的计算参考:将vmlinuz解压为vmlinux的方法
运行
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| # [ -e socket ] && rm -f socket // 记得每次删除socket文件 # ./stratovirt \ -m 1G \ -kernel vmlinux.bin \ -append "rdinit=/bin/sh console=ttyS0 root=/dev/ram panic=1" \ -initrd initramfs.img \ -api-channel unix:socket \ -serial stdio
[ 0.000000] Linux version 4.18.0-80.el8.x86_64 (mockbuild@kbuilder.bsys.centos.org) (gcc version 8.2.1 20180905 (Red Hat 8.2.1-3) (GCC)) #1 SMP Tue Jun 4 09:19:46 UTC 2019 [ 0.000000] Command line: rdinit=/bin/sh console=ttyS0 root=/dev/ram panic=1 virtio_mmio.device=4K@0xd0000000:5 virtio_mmio.device=4K@0xd0001000:6 virtio_mmio.device=4K@0xd0002000:7 virtio_mmio.device=4K@0xd0003000:8 virtio_mmio.device=4K@0xd0004000:9 virtio_mmio.device=4K@0xd0005000:10 virtio_mmio.device=4K@0xd0006000:11 virtio_mmio.device=4K@0xd0007000:12 [ 0.000000] x86/fpu: Supporting XSAVE feature 0x001: 'x87 floating point registers' [ 0.000000] x86/fpu: Supporting XSAVE feature 0x002: 'SSE registers' [ 0.000000] x86/fpu: Supporting XSAVE feature 0x004: 'AVX registers' [ 0.000000] x86/fpu: Supporting XSAVE feature 0x008: 'MPX bounds registers' [ 0.000000] x86/fpu: Supporting XSAVE feature 0x010: 'MPX CSR' [ 0.000000] x86/fpu: xstate_offset[2]: 576, xstate_sizes[2]: 256 [ 0.000000] x86/fpu: xstate_offset[3]: 832, xstate_sizes[3]: 64 ...
|