From: Fabiano Rosas <farosas@suse.de>
To: qemu-devel@nongnu.org
Cc: berrange@redhat.com, armbru@redhat.com,
Peter Xu <peterx@redhat.com>, Claudio Fontana <cfontana@suse.de>
Subject: [PATCH v4 00/34] migration: File based migration with multifd and fixed-ram
Date: Tue, 20 Feb 2024 19:41:04 -0300 [thread overview]
Message-ID: <20240220224138.24759-1-farosas@suse.de> (raw)
Hi,
In this v4:
- Added support for 'fd:'. With fixed-ram, that comes free by the
existing routing to file.c. With multifd I added a loop to create
the channels.
- Dropped support for direct-io with fixed-ram _without_ multifd. This
is something I said I would do for this version, but I had to drop
it because performance is really bad. I think the single-threaded
precopy code cannot cope with the extra latency/synchronicity of
O_DIRECT.
- Dropped QIOTask related changes. The file migration now calls
multifd_channel_connect() directly. Any error can now be returned
all the way up to migrate_fd_connect(). We can also skip the
channels_created semaphore logic when using fixed-ram.
- Moved the pwritev_read_contiguous code into a migration-specific
file and dropped the write_base trick.
- Reduced the number of syncs to just one every ram iteration and one
at the end on the send side; and a single one at the end on the recv
side. The EOS flag cannot be skipped because it is used in control
flow at ram_load_precopy.
The rest are minor changes, I have noted them in the patches
themselves.
CI run: https://gitlab.com/farosas/qemu/-/pipelines/1183853433
Series structure
================
This series enables fixed-ram in steps:
0) Cleanups [1-5]
1) QIOChannel interfaces [6-10]
2) Fixed-ram format for precopy [11-15]
3) Multifd adaptation without packets [16-19]
4) Fixed-ram format for multifd [20-26]
5) Direct-io generic support [27]
6) Direct-io for fixed-ram multifd with file: URI [28-29]
7) Fdset interface for fixed-ram multifd [30-34]
The majority of changes for this version are at step 3 due to the
rebase on top of the recent multifd cleanups.
Please take a look at the later patches in the series, step 5 onwards.
About fixed-ram
===============
Fixed-ram is a new stream format for the RAM section designed to
supplement the existing ``file:`` migration and make it compatible
with ``multifd``. This enables parallel migration of a guest's RAM to
a file.
The core of the feature is to ensure that each RAM page has a specific
offset in the resulting migration file. This enables the ``multifd``
threads to write exclusively to those offsets even if the guest is
constantly dirtying pages (i.e. live migration).
Another benefit is that the resulting file will have a bounded size,
since pages which are dirtied multiple times will always go to a fixed
location in the file, rather than constantly being added to a
sequential stream.
Having the pages at fixed offsets also allows the usage of O_DIRECT
for save/restore of the migration stream as the pages are ensured to
be written respecting O_DIRECT alignment restrictions.
Latest numbers
==============
=> guest: 128 GB RAM - 120 GB dirty - 1 vcpu in tight loop dirtying memory
=> host: 128 CPU AMD EPYC 7543 - 2 NVMe disks in RAID0 (8586 MiB/s) - xfs
=> pinned vcpus w/ NUMA shortest distances - average of 3 runs - results
from query-migrate
non-live | time (ms) pages/s mb/s MB/s
-------------------+-----------------------------------
file | 110512 256258 9549 1193
+ bg-snapshot | 245660 119581 4303 537
-------------------+-----------------------------------
fixed-ram | 157975 216877 6672 834
+ multifd 8 ch. | 95922 292178 10982 1372
+ direct-io | 23268 1936897 45330 5666
-------------------------------------------------------
live | time (ms) pages/s mb/s MB/s
-------------------+-----------------------------------
file | - - - - (file grew 4x the VM size)
+ bg-snapshot | 357635 141747 2974 371
-------------------+-----------------------------------
fixed-ram | - - - - (no convergence in 5 min)
+ multifd 8 ch. | 230812 497551 14900 1862
+ direct-io | 27475 1788025 46736 5842
-------------------------------------------------------
Previous versions of this patchset have shown performance closer to
disk saturation, but due to the query-migrate bug[1] it's hard to be
confident in the previous numbers. I don't discard the possibility of
a performance regression, but for now I can't spot anything that could
have caused it.
1- https://lore.kernel.org/r/20240219194457.26923-1-farosas@suse.de
v3:
https://lore.kernel.org/r/20231127202612.23012-1-farosas@suse.de
v2:
https://lore.kernel.org/r/20231023203608.26370-1-farosas@suse.de
v1:
https://lore.kernel.org/r/20230330180336.2791-1-farosas@suse.de
Fabiano Rosas (31):
docs/devel/migration.rst: Document the file transport
tests/qtest/migration: Rename fd_proto test
tests/qtest/migration: Add a fd + file test
migration/multifd: Remove p->quit from recv side
migration/multifd: Release recv sem_sync earlier
io: fsync before closing a file channel
migration/qemu-file: add utility methods for working with seekable
channels
migration/ram: Introduce 'fixed-ram' migration capability
migration: Add fixed-ram URI compatibility check
migration/ram: Add outgoing 'fixed-ram' migration
migration/ram: Add incoming 'fixed-ram' migration
tests/qtest/migration: Add tests for fixed-ram file-based migration
migration/multifd: Rename MultiFDSend|RecvParams::data to
compress_data
migration/multifd: Decouple recv method from pages
migration/multifd: Allow multifd without packets
migration/multifd: Allow receiving pages without packets
migration/multifd: Add outgoing QIOChannelFile support
migration/multifd: Add incoming QIOChannelFile support
migration/multifd: Prepare multifd sync for fixed-ram migration
migration/multifd: Support outgoing fixed-ram stream format
migration/multifd: Support incoming fixed-ram stream format
migration/multifd: Add fixed-ram support to fd: URI
tests/qtest/migration: Add a multifd + fixed-ram migration test
migration: Add direct-io parameter
migration/multifd: Add direct-io support
tests/qtest/migration: Add tests for file migration with direct-io
monitor: Honor QMP request for fd removal immediately
monitor: Extract fdset fd flags comparison into a function
monitor: fdset: Match against O_DIRECT
migration: Add support for fdset with multifd + file
tests/qtest/migration: Add a test for fixed-ram with passing of fds
Nikolay Borisov (3):
io: add and implement QIO_CHANNEL_FEATURE_SEEKABLE for channel file
io: Add generic pwritev/preadv interface
io: implement io_pwritev/preadv for QIOChannelFile
docs/devel/migration/features.rst | 1 +
docs/devel/migration/fixed-ram.rst | 137 +++++++++
docs/devel/migration/main.rst | 22 ++
include/exec/ramblock.h | 13 +
include/io/channel.h | 83 ++++++
include/migration/qemu-file-types.h | 2 +
include/qemu/bitops.h | 13 +
include/qemu/osdep.h | 2 +
io/channel-file.c | 69 +++++
io/channel.c | 58 ++++
migration/fd.c | 30 ++
migration/fd.h | 1 +
migration/file.c | 258 +++++++++++++++-
migration/file.h | 9 +
migration/migration-hmp-cmds.c | 11 +
migration/migration.c | 68 ++++-
migration/multifd-zlib.c | 26 +-
migration/multifd-zstd.c | 26 +-
migration/multifd.c | 436 +++++++++++++++++++++-------
migration/multifd.h | 27 +-
migration/options.c | 66 +++++
migration/options.h | 2 +
migration/qemu-file.c | 106 +++++++
migration/qemu-file.h | 6 +
migration/ram.c | 333 ++++++++++++++++++++-
migration/ram.h | 1 +
migration/savevm.c | 1 +
monitor/fds.c | 27 +-
qapi/migration.json | 24 +-
tests/qtest/migration-helpers.c | 42 +++
tests/qtest/migration-helpers.h | 1 +
tests/qtest/migration-test.c | 303 ++++++++++++++++++-
util/osdep.c | 9 +
33 files changed, 2041 insertions(+), 172 deletions(-)
create mode 100644 docs/devel/migration/fixed-ram.rst
--
2.35.3
next reply other threads:[~2024-02-20 22:42 UTC|newest]
Thread overview: 79+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-02-20 22:41 Fabiano Rosas [this message]
2024-02-20 22:41 ` [PATCH v4 01/34] docs/devel/migration.rst: Document the file transport Fabiano Rosas
2024-02-23 3:01 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 02/34] tests/qtest/migration: Rename fd_proto test Fabiano Rosas
2024-02-23 3:03 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 03/34] tests/qtest/migration: Add a fd + file test Fabiano Rosas
2024-02-23 3:08 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 04/34] migration/multifd: Remove p->quit from recv side Fabiano Rosas
2024-02-23 3:13 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 05/34] migration/multifd: Release recv sem_sync earlier Fabiano Rosas
2024-02-23 3:16 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 06/34] io: add and implement QIO_CHANNEL_FEATURE_SEEKABLE for channel file Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 07/34] io: Add generic pwritev/preadv interface Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 08/34] io: implement io_pwritev/preadv for QIOChannelFile Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 09/34] io: fsync before closing a file channel Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 10/34] migration/qemu-file: add utility methods for working with seekable channels Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 11/34] migration/ram: Introduce 'fixed-ram' migration capability Fabiano Rosas
2024-02-21 8:41 ` Markus Armbruster
2024-02-21 13:24 ` Fabiano Rosas
2024-02-21 13:50 ` Daniel P. Berrangé
2024-02-21 15:05 ` Fabiano Rosas
2024-02-26 3:07 ` Peter Xu
2024-02-26 3:22 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 12/34] migration: Add fixed-ram URI compatibility check Fabiano Rosas
2024-02-26 3:11 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 13/34] migration/ram: Add outgoing 'fixed-ram' migration Fabiano Rosas
2024-02-26 4:03 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 14/34] migration/ram: Add incoming " Fabiano Rosas
2024-02-26 5:19 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 15/34] tests/qtest/migration: Add tests for fixed-ram file-based migration Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 16/34] migration/multifd: Rename MultiFDSend|RecvParams::data to compress_data Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 17/34] migration/multifd: Decouple recv method from pages Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 18/34] migration/multifd: Allow multifd without packets Fabiano Rosas
2024-02-26 5:57 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 19/34] migration/multifd: Allow receiving pages " Fabiano Rosas
2024-02-26 6:58 ` Peter Xu
2024-02-26 19:19 ` Fabiano Rosas
2024-02-26 20:54 ` Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 20/34] migration/multifd: Add outgoing QIOChannelFile support Fabiano Rosas
2024-02-26 7:10 ` Peter Xu
2024-02-26 7:21 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 21/34] migration/multifd: Add incoming " Fabiano Rosas
2024-02-26 7:34 ` Peter Xu
2024-02-26 7:53 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 22/34] migration/multifd: Prepare multifd sync for fixed-ram migration Fabiano Rosas
2024-02-26 7:47 ` Peter Xu
2024-02-26 22:52 ` Fabiano Rosas
2024-02-27 3:52 ` Peter Xu
2024-02-27 14:00 ` Fabiano Rosas
2024-02-27 23:46 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 23/34] migration/multifd: Support outgoing fixed-ram stream format Fabiano Rosas
2024-02-26 8:08 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 24/34] migration/multifd: Support incoming " Fabiano Rosas
2024-02-26 8:30 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 25/34] migration/multifd: Add fixed-ram support to fd: URI Fabiano Rosas
2024-02-26 8:37 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 26/34] tests/qtest/migration: Add a multifd + fixed-ram migration test Fabiano Rosas
2024-02-26 8:42 ` Peter Xu
2024-02-20 22:41 ` [PATCH v4 27/34] migration: Add direct-io parameter Fabiano Rosas
2024-02-21 9:17 ` Markus Armbruster
2024-02-26 8:50 ` Peter Xu
2024-02-26 13:28 ` Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 28/34] migration/multifd: Add direct-io support Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 29/34] tests/qtest/migration: Add tests for file migration with direct-io Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 30/34] monitor: Honor QMP request for fd removal immediately Fabiano Rosas
2024-02-21 9:20 ` Markus Armbruster
2024-02-20 22:41 ` [PATCH v4 31/34] monitor: Extract fdset fd flags comparison into a function Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 32/34] monitor: fdset: Match against O_DIRECT Fabiano Rosas
2024-02-21 9:27 ` Markus Armbruster
2024-02-21 13:37 ` Fabiano Rosas
2024-02-22 6:56 ` Markus Armbruster
2024-02-22 13:26 ` Fabiano Rosas
2024-02-22 14:44 ` Markus Armbruster
2024-02-20 22:41 ` [PATCH v4 33/34] migration: Add support for fdset with multifd + file Fabiano Rosas
2024-02-20 22:41 ` [PATCH v4 34/34] tests/qtest/migration: Add a test for fixed-ram with passing of fds Fabiano Rosas
2024-02-23 2:59 ` [PATCH v4 00/34] migration: File based migration with multifd and fixed-ram Peter Xu
2024-02-23 13:48 ` Claudio Fontana
2024-02-23 14:22 ` Fabiano Rosas
2024-02-26 6:15 ` Peter Xu
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=20240220224138.24759-1-farosas@suse.de \
--to=farosas@suse.de \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=cfontana@suse.de \
--cc=peterx@redhat.com \
--cc=qemu-devel@nongnu.org \
/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).