22b7cb2c79
Currently, guestperf does not cover the dirty-limit migration, support this feature. Note that dirty-limit requires 'dirty-ring-size' set. To enable dirty-limit, setting x-vcpu-dirty-limit-period as 500ms and x-vcpu-dirty-limit as 10MB/s: $ ./tests/migration/guestperf.py \ --dirty-ring-size 4096 \ --dirty-limit --x-vcpu-dirty-limit-period 500 \ --vcpu-dirty-limit 10 --output output.json \ To run the entire standardized set of dirty-limit-enabled comparisons, with unix migration: $ ./tests/migration/guestperf-batch.py \ --dirty-ring-size 4096 \ --dst-host localhost --transport unix \ --filter compr-dirty-limit* --output outputdir Signed-off-by: Hyman Huang <yong.huang@smartx.com> Reviewed-by: Fabiano Rosas <farosas@suse.de> Message-Id: <516e7a55dfc6e33d33510be37eb24223de5dc072.1697815117.git.yong.huang@smartx.com> Message-ID: <e1283565b00b34b0377bbd27bee4bb8fc7c255a8.1698847223.git.yong.huang@smartx.com> Signed-off-by: Juan Quintela <quintela@redhat.com>
113 lines
4.1 KiB
Python
113 lines
4.1 KiB
Python
#
|
|
# Migration test scenario parameter description
|
|
#
|
|
# Copyright (c) 2016 Red Hat, Inc.
|
|
#
|
|
# This library is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
# License as published by the Free Software Foundation; either
|
|
# version 2.1 of the License, or (at your option) any later version.
|
|
#
|
|
# This library is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
# Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
|
|
class Scenario(object):
|
|
|
|
def __init__(self, name,
|
|
downtime=500,
|
|
bandwidth=125000, # 1000 gig-e, effectively unlimited
|
|
max_iters=30,
|
|
max_time=300,
|
|
pause=False, pause_iters=5,
|
|
post_copy=False, post_copy_iters=5,
|
|
auto_converge=False, auto_converge_step=10,
|
|
compression_mt=False, compression_mt_threads=1,
|
|
compression_xbzrle=False, compression_xbzrle_cache=10,
|
|
multifd=False, multifd_channels=2,
|
|
dirty_limit=False, x_vcpu_dirty_limit_period=500,
|
|
vcpu_dirty_limit=1):
|
|
|
|
self._name = name
|
|
|
|
# General migration tunables
|
|
self._downtime = downtime # milliseconds
|
|
self._bandwidth = bandwidth # MiB per second
|
|
self._max_iters = max_iters
|
|
self._max_time = max_time # seconds
|
|
|
|
|
|
# Strategies for ensuring completion
|
|
self._pause = pause
|
|
self._pause_iters = pause_iters
|
|
|
|
self._post_copy = post_copy
|
|
self._post_copy_iters = post_copy_iters
|
|
|
|
self._auto_converge = auto_converge
|
|
self._auto_converge_step = auto_converge_step # percentage CPU time
|
|
|
|
self._compression_mt = compression_mt
|
|
self._compression_mt_threads = compression_mt_threads
|
|
|
|
self._compression_xbzrle = compression_xbzrle
|
|
self._compression_xbzrle_cache = compression_xbzrle_cache # percentage of guest RAM
|
|
|
|
self._multifd = multifd
|
|
self._multifd_channels = multifd_channels
|
|
|
|
self._dirty_limit = dirty_limit
|
|
self._x_vcpu_dirty_limit_period = x_vcpu_dirty_limit_period
|
|
self._vcpu_dirty_limit = vcpu_dirty_limit
|
|
|
|
def serialize(self):
|
|
return {
|
|
"name": self._name,
|
|
"downtime": self._downtime,
|
|
"bandwidth": self._bandwidth,
|
|
"max_iters": self._max_iters,
|
|
"max_time": self._max_time,
|
|
"pause": self._pause,
|
|
"pause_iters": self._pause_iters,
|
|
"post_copy": self._post_copy,
|
|
"post_copy_iters": self._post_copy_iters,
|
|
"auto_converge": self._auto_converge,
|
|
"auto_converge_step": self._auto_converge_step,
|
|
"compression_mt": self._compression_mt,
|
|
"compression_mt_threads": self._compression_mt_threads,
|
|
"compression_xbzrle": self._compression_xbzrle,
|
|
"compression_xbzrle_cache": self._compression_xbzrle_cache,
|
|
"multifd": self._multifd,
|
|
"multifd_channels": self._multifd_channels,
|
|
"dirty_limit": self._dirty_limit,
|
|
"x_vcpu_dirty_limit_period": self._x_vcpu_dirty_limit_period,
|
|
"vcpu_dirty_limit": self._vcpu_dirty_limit,
|
|
}
|
|
|
|
@classmethod
|
|
def deserialize(cls, data):
|
|
return cls(
|
|
data["name"],
|
|
data["downtime"],
|
|
data["bandwidth"],
|
|
data["max_iters"],
|
|
data["max_time"],
|
|
data["pause"],
|
|
data["pause_iters"],
|
|
data["post_copy"],
|
|
data["post_copy_iters"],
|
|
data["auto_converge"],
|
|
data["auto_converge_step"],
|
|
data["compression_mt"],
|
|
data["compression_mt_threads"],
|
|
data["compression_xbzrle"],
|
|
data["compression_xbzrle_cache"],
|
|
data["multifd"],
|
|
data["multifd_channels"])
|