[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 00/10] *** A Method for evaluating dirty page rate ***
From: |
Chuan Zheng |
Subject: |
[PATCH v2 00/10] *** A Method for evaluating dirty page rate *** |
Date: |
Sat, 15 Aug 2020 10:22:50 +0800 |
v1 -> v2:
use g_rand_new() to generate rand_buf
move RAMBLOCK_FOREACH_MIGRATABLE into migration/ram.h
add skip_sample_ramblock to filter sampled ramblock
fix multi-numa vm coredump when query dirtyrate
rename qapi interface and rename some structures and functions
succeed to compile by appling each patch
add test for migrating vm
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.
Evaluate the dirtypage rate both on running and migration 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);
- migration bandwidth is 1GB/s
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
| | running | migrating
|
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
| no mempress | 4MB/s | 8MB/s (migrated success)
|
------------------------------------------------------------------------------------
| mempress 4096 1024 | 1188MB/s | 536MB/s ~ 1044MB/s (cpu throttle
triggered) |
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
| mempress 4096 4096 | 4152MB/s | 608MB/s ~ 4125MB/s (migation failed)
|
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Test dirtyrate by qmp command like this:
1. virsh qemu-monitor-command [vmname] '{"execute":"calc-dirty-rate",
"arguments": {"calc-time": [sleep-time]}}';
2. sleep specific time which is a bit larger than sleep-time
3. virsh qemu-monitor-command [vmname] '{"execute":"query-dirty-rate"}'
Further test dirtyrate by libvirt api like this:
virsh getdirtyrate [vmname] [sleep-time]
Zheng Chuan (10):
migration/dirtyrate: Add get_dirtyrate_thread() function
migration/dirtyrate: Add RamlockDirtyInfo to store sampled page info
migration/dirtyrate: Add dirtyrate statistics series functions
migration/dirtyrate: move RAMBLOCK_FOREACH_MIGRATABLE into ram.h
migration/dirtyrate: Record hash results for each sampled page
migration/dirtyrate: Compare page hash results for recorded sampled
page
migration/dirtyrate: skip sampling ramblock with size below
MIN_RAMBLOCK_SIZE
migration/dirtyrate: Implement get_sample_page_period() and
block_sample_page_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 | 448 ++++++++++++++++++++++++++++++++++++++++++++++++
migration/dirtyrate.h | 86 ++++++++++
migration/ram.c | 11 +-
migration/ram.h | 10 ++
qapi/migration.json | 42 +++++
6 files changed, 588 insertions(+), 10 deletions(-)
create mode 100644 migration/dirtyrate.c
create mode 100644 migration/dirtyrate.h
--
1.8.3.1
- [PATCH v2 00/10] *** A Method for evaluating dirty page rate ***, Chuan Zheng, 2020/08/14
- [PATCH v2 06/10] migration/dirtyrate: Compare page hash results for recorded sampled page, Chuan Zheng, 2020/08/14
- [PATCH v2 05/10] migration/dirtyrate: Record hash results for each sampled page, Chuan Zheng, 2020/08/14
- [PATCH v2 02/10] migration/dirtyrate: Add RamlockDirtyInfo to store sampled page info, Chuan Zheng, 2020/08/14
- [PATCH v2 07/10] migration/dirtyrate: skip sampling ramblock with size below MIN_RAMBLOCK_SIZE, Chuan Zheng, 2020/08/14
- [PATCH v2 08/10] migration/dirtyrate: Implement get_sample_page_period() and block_sample_page_period(), Chuan Zheng, 2020/08/14
- [PATCH v2 09/10] migration/dirtyrate: Implement calculate_dirtyrate() function, Chuan Zheng, 2020/08/14
- [PATCH v2 03/10] migration/dirtyrate: Add dirtyrate statistics series functions, Chuan Zheng, 2020/08/14
- [PATCH v2 01/10] migration/dirtyrate: Add get_dirtyrate_thread() function, Chuan Zheng, 2020/08/14
- [PATCH v2 04/10] migration/dirtyrate: move RAMBLOCK_FOREACH_MIGRATABLE into ram.h, Chuan Zheng, 2020/08/14
- [PATCH v2 00/10] *** A Method for evaluating dirty page rate ***,
Chuan Zheng <=
- [PATCH v2 02/10] migration/dirtyrate: Add RamlockDirtyInfo to store sampled page info, Chuan Zheng, 2020/08/15
- [PATCH v2 10/10] migration/dirtyrate: Implement qmp_cal_dirty_rate()/qmp_get_dirty_rate() function, Chuan Zheng, 2020/08/15
- [PATCH v2 09/10] migration/dirtyrate: Implement calculate_dirtyrate() function, Chuan Zheng, 2020/08/15
- [PATCH v2 08/10] migration/dirtyrate: Implement get_sample_page_period() and block_sample_page_period(), Chuan Zheng, 2020/08/15
- [PATCH v2 05/10] migration/dirtyrate: Record hash results for each sampled page, Chuan Zheng, 2020/08/15
- [PATCH v2 03/10] migration/dirtyrate: Add dirtyrate statistics series functions, Chuan Zheng, 2020/08/15
- [PATCH v2 04/10] migration/dirtyrate: move RAMBLOCK_FOREACH_MIGRATABLE into ram.h, Chuan Zheng, 2020/08/15
- [PATCH v2 06/10] migration/dirtyrate: Compare page hash results for recorded sampled page, Chuan Zheng, 2020/08/15
- [PATCH v2 07/10] migration/dirtyrate: skip sampling ramblock with size below MIN_RAMBLOCK_SIZE, Chuan Zheng, 2020/08/15
- [PATCH v2 01/10] migration/dirtyrate: Add get_dirtyrate_thread() function, Chuan Zheng, 2020/08/15