2020-04-08 17:15:09 +08:00
|
|
|
# How to test vhost-user-blk with SPDK
|
|
|
|
|
|
|
|
The purpose of this document is to illustrate how to test vhost-user-blk in Cloud Hypervisor with SPDK as the backend.
|
|
|
|
|
|
|
|
## Framework
|
|
|
|
|
|
|
|
It's a simple test to validate the block read/write between VM and block backend.
|
|
|
|
```
|
|
|
|
+----+----------+ +-------------+-----------+
|
|
|
|
| | | | | |
|
|
|
|
| |vhost-user|----------| vhost-user | dpdk |
|
|
|
|
| |blk device| | port 1 | |
|
|
|
|
| | | | | |
|
|
|
|
| +----------+ +-------------+-----------+
|
|
|
|
| | | |
|
|
|
|
| vm | | spdk |
|
|
|
|
| | | |
|
|
|
|
+--+----------------------------------------------------+--+
|
|
|
|
| | hugepages | |
|
|
|
|
| +----------------------------------------------------+ |
|
|
|
|
| |
|
|
|
|
| host |
|
|
|
|
| |
|
|
|
|
+----------------------------------------------------------+
|
|
|
|
```
|
|
|
|
## Prerequisites
|
|
|
|
|
|
|
|
Prior to running the test, the following steps need to be performed.
|
|
|
|
- Enable hugepages
|
|
|
|
- Install SPDK
|
|
|
|
|
|
|
|
Here are some good references for detailing them.
|
|
|
|
- spdk
|
|
|
|
* https://spdk.io/doc/
|
|
|
|
|
|
|
|
## Test environment
|
|
|
|
|
2021-05-03 14:43:18 -07:00
|
|
|
The below test environment is based on Ubuntu release (20.04.1 LTS), as for other system, please check related documents.
|
|
|
|
This test runs with multiple queue (MQ) support enabled, using 4 queues defined for both SPDK and the virtual machine.
|
|
|
|
Here are the detailed instructions.
|
2020-04-08 17:15:09 +08:00
|
|
|
|
2021-05-03 14:43:18 -07:00
|
|
|
### The hugepages settings on the host
|
|
|
|
Allocate enough persistent huge pages (e.g. 2GiB) on the host:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
# Assume the default hugepage size is 2MiB
|
|
|
|
echo 1024 | sudo tee /proc/sys/vm/nr_hugepages
|
|
|
|
# Confirm the value of "Hugepagesize" and "HugePages_Total"
|
|
|
|
cat /proc/meminfo | grep -i huge
|
|
|
|
```
|
2020-04-08 17:15:09 +08:00
|
|
|
|
|
|
|
### Download the SPDK code
|
2021-05-03 14:43:18 -07:00
|
|
|
```bash
|
2020-04-08 17:15:09 +08:00
|
|
|
git clone https://github.com/spdk/spdk
|
|
|
|
cd spdk
|
|
|
|
git submodule update --init
|
2021-05-03 14:43:18 -07:00
|
|
|
```
|
2020-04-08 17:15:09 +08:00
|
|
|
|
|
|
|
### Create the build dep
|
2021-05-03 14:43:18 -07:00
|
|
|
|
|
|
|
```bash
|
2020-04-08 17:15:09 +08:00
|
|
|
./scripts/pkgdep.sh
|
2021-05-03 14:43:18 -07:00
|
|
|
```
|
2020-04-08 17:15:09 +08:00
|
|
|
|
2021-05-03 14:43:18 -07:00
|
|
|
### Build SPDK
|
|
|
|
```bash
|
2020-04-08 17:15:09 +08:00
|
|
|
./configure
|
|
|
|
make
|
2021-05-03 14:43:18 -07:00
|
|
|
```
|
2020-04-08 17:15:09 +08:00
|
|
|
|
2021-05-03 14:43:18 -07:00
|
|
|
### Set the SPDK environment
|
2021-11-11 04:10:10 +00:00
|
|
|
|
|
|
|
Run SPDK vhost target with 2 CPU cores, i.e., core 0 and 1.
|
2021-05-03 14:43:18 -07:00
|
|
|
```bash
|
2020-04-08 17:15:09 +08:00
|
|
|
sudo HUGEMEM=2048 scripts/setup.sh
|
2021-05-03 14:43:18 -07:00
|
|
|
sudo ./build/bin/vhost -S /var/tmp -s 1024 -m 0x3 &
|
|
|
|
```
|
2020-04-08 17:15:09 +08:00
|
|
|
|
|
|
|
### Create 512M block device
|
2021-11-11 04:10:10 +00:00
|
|
|
|
|
|
|
Create a 512M (first parameter) block device with 512 bytes (second parameter) block size.
|
2021-05-03 14:43:18 -07:00
|
|
|
```bash
|
2020-04-08 17:15:09 +08:00
|
|
|
sudo scripts/rpc.py bdev_malloc_create 512 512 -b Malloc0
|
|
|
|
sudo scripts/rpc.py vhost_create_blk_controller --cpumask 0x1 vhost.1 Malloc0
|
2021-05-03 14:43:18 -07:00
|
|
|
```
|
2020-04-08 17:15:09 +08:00
|
|
|
|
2021-05-03 14:43:18 -07:00
|
|
|
### Launch the VM
|
2020-04-08 17:15:09 +08:00
|
|
|
|
|
|
|
VMs run in client mode. They connect to the socket created by the `dpdkvhostuser` in the SPDK backend.
|
|
|
|
```bash
|
|
|
|
# From the test terminal. We need to create one vhost-user-blk device for the --disk.
|
|
|
|
./cloud-hypervisor \
|
|
|
|
--cpus boot=4 \
|
2020-08-07 12:22:51 +00:00
|
|
|
--memory size=1024M,hugepages=on,shared=true \
|
2020-04-08 17:15:09 +08:00
|
|
|
--kernel linux/arch/x86/boot/compressed/vmlinux.bin \
|
2020-07-02 18:30:16 +02:00
|
|
|
--cmdline "console=ttyS0 root=/dev/vda1 rw iommu=off" \
|
2023-09-11 18:32:41 +03:00
|
|
|
--disk path=images/focal-server-cloudimg-amd64.raw vhost_user=true,socket=/var/tmp/vhost.1,num_queues=4,queue_size=128 \
|
2020-04-08 17:15:09 +08:00
|
|
|
--console off \
|
|
|
|
--serial tty \
|
|
|
|
--rng
|
|
|
|
```
|
|
|
|
|
|
|
|
```bash
|
|
|
|
# How to test the vhost-user-blk device with SPDK backend
|
|
|
|
login in guest
|
|
|
|
|
|
|
|
# Use lsblk command to find out vhost-user-blk device
|
|
|
|
lsblk
|
2020-07-02 18:30:16 +02:00
|
|
|
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
|
2021-05-03 14:43:18 -07:00
|
|
|
vda 252:0 0 2.2G 0 disk
|
2020-07-02 18:30:16 +02:00
|
|
|
├─vda1 252:1 0 2.1G 0 part /
|
2021-05-03 14:43:18 -07:00
|
|
|
├─vda14 252:14 0 4M 0 part
|
2020-07-02 18:30:16 +02:00
|
|
|
└─vda15 252:15 0 106M 0 part /boot/efi
|
2020-04-08 17:15:09 +08:00
|
|
|
vdb 253:16 0 512M 0 disk
|
|
|
|
|
|
|
|
The vhost-user-blk device is /dev/vdb
|
|
|
|
|
|
|
|
# How to do simple read/write test
|
|
|
|
dd if=/dev/vdb of=/dev/null bs=2M iflag=direct
|
|
|
|
dd of=/dev/vdb if=/dev/zero bs=2M oflag=direct count=256
|
|
|
|
|
|
|
|
If you want to do fio test, please install fio binary into guest. The detailed info is not listed here.
|