[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[RFC PATCH 0/8] *** A Method for evaluating dirty page rate ***
From: |
Chuan Zheng |
Subject: |
[RFC PATCH 0/8] *** A Method for evaluating dirty page rate *** |
Date: |
Sat, 25 Jul 2020 11:11:01 +0800 |
From: Zheng Chuan <zhengchuan@huawei.com>
Sometimes it is neccessary to evaluate dirty page rate before migration.
Users could decide whether to proceed migration based on the evaluation
in case of vm performance loss due to heavy workload.
Unlikey simulating dirtylog sync which could do harm on runnning vm,
we provide a sample-hash method to compare hash results for samping page.
In this way, it would have hardly no impact on vm performance.
We evaluate the dirtypage rate on running vm.
The VM specifications for migration are as follows:
- VM use 4-K page;
- the number of VCPU is 32;
- the total memory is 32Gigabit;
- use 'mempress' tool to pressurize VM(mempress 4096 1024);
++++++++++++++++++++++++++++++++++++++++++
| | dirtyrate |
++++++++++++++++++++++++++++++++++++++++++
| no mempress | 4MB/s |
------------------------------------------
| mempress 4096 1024 | 1204MB/s |
++++++++++++++++++++++++++++++++++++++++++
| mempress 4096 4096 | 4000Mb/s |
++++++++++++++++++++++++++++++++++++++++++
Test dirtyrate by qmp command like this:
1. virsh qemu-monitor-command [vmname] '{"execute":"cal_dirty_rate",
"arguments": {"value": [sampletime]}}'
2. virsh qemu-monitor-command [vmname] '{"execute":"get_dirty_rate"}'
Further test dirtyrate by libvirt api like this:
virsh getdirtyrate [vmname] [sampletime]
Zheng Chuan (8):
migration/dirtyrate: Add get_dirtyrate_thread() function
migration/dirtyrate: Add block_dirty_info to store dirtypage info
migration/dirtyrate: Add dirtyrate statistics series functions
migration/dirtyrate: Record hash results for each ramblock
migration/dirtyrate: Compare hash results for recorded ramblock
migration/dirtyrate: Implement get_sample_gap_period() and
block_sample_gap_period()
migration/dirtyrate: Implement calculate_dirtyrate() function
migration/dirtyrate: Implement
qmp_cal_dirty_rate()/qmp_get_dirty_rate() function
migration/Makefile.objs | 1 +
migration/dirtyrate.c | 424 ++++++++++++++++++++++++++++++++++++++++++++++++
migration/dirtyrate.h | 67 ++++++++
qapi/migration.json | 24 +++
qapi/pragma.json | 3 +-
5 files changed, 518 insertions(+), 1 deletion(-)
create mode 100644 migration/dirtyrate.c
create mode 100644 migration/dirtyrate.h
--
1.8.3.1
- [RFC PATCH 0/8] *** A Method for evaluating dirty page rate ***,
Chuan Zheng <=
- [RFC PATCH 3/8] migration/dirtyrate: Add dirtyrate statistics series functions, Chuan Zheng, 2020/07/24
- [RFC PATCH 4/8] migration/dirtyrate: Record hash results for each ramblock, Chuan Zheng, 2020/07/24
- [RFC PATCH 1/8] migration/dirtyrate: Add get_dirtyrate_thread() function, Chuan Zheng, 2020/07/24
- [RFC PATCH 7/8] migration/dirtyrate: Implement calculate_dirtyrate() function, Chuan Zheng, 2020/07/24
- [RFC PATCH 2/8] migration/dirtyrate: Add block_dirty_info to store dirtypage info, Chuan Zheng, 2020/07/24
- [RFC PATCH 6/8] migration/dirtyrate: Implement get_sample_gap_period() and block_sample_gap_period(), Chuan Zheng, 2020/07/24
- [RFC PATCH 5/8] migration/dirtyrate: Compare hash results for recorded ramblock, Chuan Zheng, 2020/07/24
- [RFC PATCH 8/8] migration/dirtyrate: Implement qmp_cal_dirty_rate()/qmp_get_dirty_rate() function, Chuan Zheng, 2020/07/24