From: Hyman Huang <huangy81@chinatelecom.cn>
To: qemu-devel <qemu-devel@nongnu.org>,
"Daniel P. Berrangé" <berrange@redhat.com>,
"Thomas Huth" <thuth@redhat.com>
Cc: "Dr. David Alan Gilbert" <dgilbert@redhat.com>,
Juan Quintela <quintela@redhat.com>
Subject: Re: [PATCH v1] tests/migration: introduce multifd into guestperf
Date: Wed, 21 Apr 2021 09:48:19 +0800 [thread overview]
Message-ID: <e8233048-ceb6-fa2f-76f8-523073ff29da@chinatelecom.cn> (raw)
In-Reply-To: <4a492050-4a4a-724a-b328-6d69643e86b4@chinatelecom.cn>
在 2021/3/24 9:18, Hyman Huang 写道:
> cc thuth@redhat.com and berrange@redhat.com
>
> Please review, thanks
>
> 在 2021/3/20 1:04, huangy81@chinatelecom.cn 写道:
>> From: Hyman <huangy81@chinatelecom.cn>
>>
>> Guestperf tool does not cover the multifd-enabled migration
>> currently, it is worth supporting so that developers can
>> analysis the migration performance with all kinds of
>> migration.
>>
>> To request that multifd is enabled, with 4 channels:
>> $ ./tests/migration/guestperf.py \
>> --multifd --multifd-channels 4 --output output.json
>>
>> To run the entire standardized set of multifd-enabled
>> comparisons, with unix migration:
>> $ ./tests/migration/guestperf-batch.py \
>> --dst-host localhost --transport unix \
>> --filter compr-multifd* --output outputdir
>>
>> Signed-off-by: Hyman Huang(黄勇) <huangy81@chinatelecom.cn>
>> ---
>> tests/migration/guestperf/comparison.py | 14 ++++++++++++++
>> tests/migration/guestperf/engine.py | 16 ++++++++++++++++
>> tests/migration/guestperf/scenario.py | 12 ++++++++++--
>> tests/migration/guestperf/shell.py | 10 +++++++++-
>> 4 files changed, 49 insertions(+), 3 deletions(-)
>>
>> diff --git a/tests/migration/guestperf/comparison.py
>> b/tests/migration/guestperf/comparison.py
>> index ba2edbe..c03b3f6 100644
>> --- a/tests/migration/guestperf/comparison.py
>> +++ b/tests/migration/guestperf/comparison.py
>> @@ -121,4 +121,18 @@ def __init__(self, name, scenarios):
>> Scenario("compr-xbzrle-cache-50",
>> compression_xbzrle=True, compression_xbzrle_cache=50),
>> ]),
>> +
>> +
>> + # Looking at effect of multifd with
>> + # varying numbers of channels
>> + Comparison("compr-multifd", scenarios = [
>> + Scenario("compr-multifd-channels-4",
>> + multifd=True, multifd_channels=2),
>> + Scenario("compr-multifd-channels-8",
>> + multifd=True, multifd_channels=8),
>> + Scenario("compr-multifd-channels-32",
>> + multifd=True, multifd_channels=32),
>> + Scenario("compr-multifd-channels-64",
>> + multifd=True, multifd_channels=64),
>> + ]),
>> ]
>> diff --git a/tests/migration/guestperf/engine.py
>> b/tests/migration/guestperf/engine.py
>> index e399447..fab3957 100644
>> --- a/tests/migration/guestperf/engine.py
>> +++ b/tests/migration/guestperf/engine.py
>> @@ -188,6 +188,22 @@ def _migrate(self, hardware, scenario, src, dst,
>> connect_uri):
>> 1024 * 1024 * 1024 / 100 *
>> scenario._compression_xbzrle_cache))
>> + if scenario._multifd:
>> + resp = src.command("migrate-set-capabilities",
>> + capabilities = [
>> + { "capability": "multifd",
>> + "state": True }
>> + ])
>> + resp = src.command("migrate-set-parameters",
>> +
>> multifd_channels=scenario._multifd_channels)
>> + resp = dst.command("migrate-set-capabilities",
>> + capabilities = [
>> + { "capability": "multifd",
>> + "state": True }
>> + ])
>> + resp = dst.command("migrate-set-parameters",
>> +
>> multifd_channels=scenario._multifd_channels)
>> +
>> resp = src.command("migrate", uri=connect_uri)
>> post_copy = False
>> diff --git a/tests/migration/guestperf/scenario.py
>> b/tests/migration/guestperf/scenario.py
>> index 28ef36c..de70d9b 100644
>> --- a/tests/migration/guestperf/scenario.py
>> +++ b/tests/migration/guestperf/scenario.py
>> @@ -29,7 +29,8 @@ def __init__(self, name,
>> 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):
>> + compression_xbzrle=False, compression_xbzrle_cache=10,
>> + multifd=False, multifd_channels=2):
>> self._name = name
>> @@ -56,6 +57,9 @@ def __init__(self, name,
>> self._compression_xbzrle = compression_xbzrle
>> self._compression_xbzrle_cache = compression_xbzrle_cache #
>> percentage of guest RAM
>> + self._multifd = multifd
>> + self._multifd_channels = multifd_channels
>> +
>> def serialize(self):
>> return {
>> "name": self._name,
>> @@ -73,6 +77,8 @@ def serialize(self):
>> "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,
>> }
>> @classmethod
>> @@ -92,4 +98,6 @@ def deserialize(cls, data):
>> data["compression_mt"],
>> data["compression_mt_threads"],
>> data["compression_xbzrle"],
>> - data["compression_xbzrle_cache"])
>> + data["compression_xbzrle_cache"],
>> + data["multifd"],
>> + data["multifd_channels"])
>> diff --git a/tests/migration/guestperf/shell.py
>> b/tests/migration/guestperf/shell.py
>> index f838888..8a809e3 100644
>> --- a/tests/migration/guestperf/shell.py
>> +++ b/tests/migration/guestperf/shell.py
>> @@ -122,6 +122,11 @@ def __init__(self):
>> parser.add_argument("--compression-xbzrle",
>> dest="compression_xbzrle", default=False, action="store_true")
>> parser.add_argument("--compression-xbzrle-cache",
>> dest="compression_xbzrle_cache", default=10, type=int)
>> + parser.add_argument("--multifd", dest="multifd", default=False,
>> + action="store_true")
>> + parser.add_argument("--multifd-channels",
>> dest="multifd_channels",
>> + default=2, type=int)
>> +
>> def get_scenario(self, args):
>> return Scenario(name="perfreport",
>> downtime=args.downtime,
>> @@ -142,7 +147,10 @@ def get_scenario(self, args):
>>
>> compression_mt_threads=args.compression_mt_threads,
>> compression_xbzrle=args.compression_xbzrle,
>> -
>> compression_xbzrle_cache=args.compression_xbzrle_cache)
>> +
>> compression_xbzrle_cache=args.compression_xbzrle_cache,
>> +
>> + multifd=args.multifd,
>> + multifd_channels=args.multifd_channels)
>> def run(self, argv):
>> args = self._parser.parse_args(argv)
>>
>
Ping - Hi, What would you think about this patch ? :)
--
Best regard
Hyman Huang(黄勇)
next prev parent reply other threads:[~2021-04-21 1:49 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-03-19 17:04 [PATCH v1] introduce multifd into guestperf huangy81
2021-03-19 17:04 ` [PATCH v1] tests/migration: " huangy81
2021-03-24 1:18 ` Hyman Huang
2021-04-21 1:48 ` Hyman Huang [this message]
2021-04-30 8:33 ` Daniel P. Berrangé
2021-05-11 9:54 ` Dr. David Alan Gilbert
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=e8233048-ceb6-fa2f-76f8-523073ff29da@chinatelecom.cn \
--to=huangy81@chinatelecom.cn \
--cc=berrange@redhat.com \
--cc=dgilbert@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=quintela@redhat.com \
--cc=thuth@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).