performance-metrics: add IOPS tests for FIO

Change fio_ops to fio_control and add a new field to indicate whether it
should report bandwidth or IOPS.

All existing tests are bandwidth tests. Adapt the code accordingly. Add
a set of new tests to report IOPS.

Signed-off-by: Wei Liu <liuwe@microsoft.com>
This commit is contained in:
Wei Liu 2023-01-03 22:31:01 +00:00 committed by Rob Bradford
parent 3de0a6d401
commit e16817ea14
2 changed files with 108 additions and 15 deletions

View File

@ -130,7 +130,7 @@ pub struct PerformanceTestControl {
num_queues: Option<u32>, num_queues: Option<u32>,
queue_size: Option<u32>, queue_size: Option<u32>,
net_rx: Option<bool>, net_rx: Option<bool>,
fio_ops: Option<FioOps>, fio_control: Option<(FioOps, bool)>, // Second parameter controls whether we want bandwidth or IOPS
num_boot_vcpus: Option<u8>, num_boot_vcpus: Option<u8>,
} }
@ -149,8 +149,9 @@ impl fmt::Display for PerformanceTestControl {
if let Some(o) = self.net_rx { if let Some(o) = self.net_rx {
output = format!("{output}, net_rx = {o}"); output = format!("{output}, net_rx = {o}");
} }
if let Some(o) = &self.fio_ops { if let Some(o) = &self.fio_control {
output = format!("{output}, fio_ops = {o}"); let (ops, bw) = o;
output = format!("{output}, fio_ops = {ops}, bandwidth = {bw}");
} }
write!(f, "{output}") write!(f, "{output}")
@ -165,7 +166,7 @@ impl PerformanceTestControl {
num_queues: None, num_queues: None,
queue_size: None, queue_size: None,
net_rx: None, net_rx: None,
fio_ops: None, fio_control: None,
num_boot_vcpus: Some(1), num_boot_vcpus: Some(1),
} }
} }
@ -262,7 +263,7 @@ mod adjuster {
} }
} }
const TEST_LIST: [PerformanceTest; 17] = [ const TEST_LIST: [PerformanceTest; 25] = [
PerformanceTest { PerformanceTest {
name: "boot_time_ms", name: "boot_time_ms",
func_ptr: performance_boot_time, func_ptr: performance_boot_time,
@ -365,7 +366,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(1), num_queues: Some(1),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::Read), fio_control: Some((FioOps::Read, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -376,7 +377,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(1), num_queues: Some(1),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::Write), fio_control: Some((FioOps::Write, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -387,7 +388,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(1), num_queues: Some(1),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::RandomRead), fio_control: Some((FioOps::RandomRead, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -398,7 +399,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(1), num_queues: Some(1),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::RandomWrite), fio_control: Some((FioOps::RandomWrite, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -409,7 +410,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(2), num_queues: Some(2),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::Read), fio_control: Some((FioOps::Read, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -420,7 +421,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(2), num_queues: Some(2),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::Write), fio_control: Some((FioOps::Write, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -431,7 +432,7 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(2), num_queues: Some(2),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::RandomRead), fio_control: Some((FioOps::RandomRead, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
@ -442,11 +443,99 @@ const TEST_LIST: [PerformanceTest; 17] = [
control: PerformanceTestControl { control: PerformanceTestControl {
num_queues: Some(2), num_queues: Some(2),
queue_size: Some(128), queue_size: Some(128),
fio_ops: Some(FioOps::RandomWrite), fio_control: Some((FioOps::RandomWrite, true)),
..PerformanceTestControl::default() ..PerformanceTestControl::default()
}, },
unit_adjuster: adjuster::Bps_to_MiBps, unit_adjuster: adjuster::Bps_to_MiBps,
}, },
PerformanceTest {
name: "block_read_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(1),
queue_size: Some(128),
fio_control: Some((FioOps::Read, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_write_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(1),
queue_size: Some(128),
fio_control: Some((FioOps::Write, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_random_read_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(1),
queue_size: Some(128),
fio_control: Some((FioOps::RandomRead, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_random_write_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(1),
queue_size: Some(128),
fio_control: Some((FioOps::RandomWrite, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_multi_queue_read_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(2),
queue_size: Some(128),
fio_control: Some((FioOps::Read, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_multi_queue_write_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(2),
queue_size: Some(128),
fio_control: Some((FioOps::Write, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_multi_queue_random_read_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(2),
queue_size: Some(128),
fio_control: Some((FioOps::RandomRead, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
PerformanceTest {
name: "block_multi_queue_random_write_IOPS",
func_ptr: performance_block_io,
control: PerformanceTestControl {
num_queues: Some(2),
queue_size: Some(128),
fio_control: Some((FioOps::RandomWrite, false)),
..PerformanceTestControl::default()
},
unit_adjuster: adjuster::identity,
},
]; ];
fn run_test_with_timeout( fn run_test_with_timeout(

View File

@ -335,7 +335,7 @@ pub fn performance_boot_time_pmem(control: &PerformanceTestControl) -> f64 {
pub fn performance_block_io(control: &PerformanceTestControl) -> f64 { pub fn performance_block_io(control: &PerformanceTestControl) -> f64 {
let test_timeout = control.test_timeout; let test_timeout = control.test_timeout;
let num_queues = control.num_queues.unwrap(); let num_queues = control.num_queues.unwrap();
let fio_ops = control.fio_ops.as_ref().unwrap(); let (fio_ops, bandwidth) = control.fio_control.as_ref().unwrap();
let focal = UbuntuDiskConfig::new(FOCAL_IMAGE_NAME.to_string()); let focal = UbuntuDiskConfig::new(FOCAL_IMAGE_NAME.to_string());
let guest = performance_test_new_guest(Box::new(focal)); let guest = performance_test_new_guest(Box::new(focal));
@ -388,7 +388,11 @@ pub fn performance_block_io(control: &PerformanceTestControl) -> f64 {
.unwrap(); .unwrap();
// Parse fio output // Parse fio output
if *bandwidth {
parse_fio_output(&output, fio_ops, num_queues).unwrap() parse_fio_output(&output, fio_ops, num_queues).unwrap()
} else {
parse_fio_output_iops(&output, fio_ops, num_queues).unwrap()
}
}); });
let _ = child.kill(); let _ = child.kill();