qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
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(黄勇)


  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).