Awesome
StratoVirt
StratoVirt is an enterprise-level virtualization platform for cloud data centers in the computing industry. It implements a set of architecture that supports three scenarios: virtual machines, containers, and serverless computing.
StratoVirt has competitive advantages in light weight and low noise, software and hardware coordination, and Rust language-level security.
StratoVirt reserves interfaces and design to support more features, now can support standard and lightweight virtualization together, as well as the ability to extend support for new heterogeneous devices.
How to start
Preparation
Before building StratoVirt, make sure that Rust language and Cargo have already been installed. If not, you can find installation guidance via following link:
https://www.rust-lang.org/tools/install
And it will get smaller memory overhead if you prepare musl toolchain for rust.
Build StratoVirt
To build StratoVirt, clone the project and build it first:
$ git clone https://gitee.com/openeuler/stratovirt.git
$ cd stratovirt
$ make build
Now you can find StratoVirt binary in target/release/stratovirt
.
Run a VM with StratoVirt
To run StratoVirt quickly, requires
- A PE or bzImage (only x86_64) format Linux kernel
- An EXT4 filesystem, raw format rootfs disk image
You can get kernel and rootfs image from the following link:
https://repo.openeuler.org/openEuler-22.03-LTS/stratovirt_img/
For standard VM, firmware file of EDK2 which follows UEFI is required.
# If the socket of qmp exists, remove it first.
# Start microvm
$ ./target/release/stratovirt \
-machine microvm \
-kernel /path/to/kernel \
-append "console=ttyS0 root=/dev/vda reboot=k panic=1" \
-drive file=/path/to/rootfs,id=rootfs,readonly=off \
-device virtio-blk-device,drive=rootfs,id=rootfs \
-qmp unix:/path/to/socket,server,nowait \
-serial stdio
# Start standard VM on x86_64
$ ./target/release/stratovirt \
-machine q35 \
-kernel /path/to/kernel \
-append "console=ttyS0 root=/dev/vda reboot=k panic=1" \
-drive file=/path/to/firmware,if=pflash,unit=0,readonly=true \
-device pcie-root-port,port=0x0,addr=0x1.0x0,bus=pcie.0,id=pcie.1 \
-drive file=/path/to/rootfs,id=rootfs,readonly=off \
-device virtio-blk-pci,drive=rootfs,bus=pcie.1,addr=0x0.0x0,id=blk-0 \
-qmp unix:/path/to/socket,server,nowait \
-serial stdio
The detailed guidance of making rootfs, compiling kernel and building StratoVirt can be found in StratoVirt QuickStart.
StratoVirt supports much more features, the detailed guidance can be found in Configuration Guidebook.
Design
To get more details about StratoVirt's core architecture design, refer to StratoVirt design.
How to contribute
We welcome new contributors! And we are happy to provide guidance and help for new contributors. StratoVirt follows Rust formatting conventions, which can be found at:
https://github.com/rust-dev-tools/fmt-rfcs/tree/master/guide https://github.com/rust-lang/rust-clippy
You can get more information about StratoVirt at:
https://gitee.com/openeuler/stratovirt/wikis
If you find a bug or have some ideas, please send an email to the virt mailing list or submit an issue.
Licensing
StratoVirt is licensed under the Mulan PSL v2.