2021-12-09 19:46:42 +00:00
|
|
|
Send/receive
|
|
|
|
============
|
2021-11-30 15:00:48 +00:00
|
|
|
|
2021-12-09 19:46:42 +00:00
|
|
|
Send and receive are complementary features that allow to transfer data from
|
|
|
|
one filesystem to another in a streamable format. The send part traverses a
|
|
|
|
given read-only subvolume and either creates a full stream representation of
|
|
|
|
its data and metadata (*full mode*), or given a set of subvolumes for reference
|
|
|
|
it generates a difference relative to that set (*incremental mode*).
|
|
|
|
|
|
|
|
Receive on the other hand takes the stream and reconstructs a subvolume with
|
|
|
|
files and directories equivalent to the filesystem that was used to produce the
|
2022-12-07 20:00:25 +00:00
|
|
|
stream. The result is not exactly 1:1, e.g. inode numbers can be different and
|
2021-12-09 19:46:42 +00:00
|
|
|
other unique identifiers can be different (like the subvolume UUIDs). The full
|
|
|
|
mode starts with an empty subvolume, creates all the files and then turns the
|
|
|
|
subvolume to read-only. At this point it could be used as a starting point for a
|
|
|
|
future incremental send stream, provided it would be generated from the same
|
|
|
|
source subvolume on the other filesystem.
|
|
|
|
|
2022-12-07 20:00:25 +00:00
|
|
|
The stream is a sequence of encoded commands that change e.g. file metadata
|
2021-12-09 19:46:42 +00:00
|
|
|
(owner, permissions, extended attributes), data extents (create, clone,
|
|
|
|
truncate), whole file operations (rename, delete). The stream can be sent over
|
|
|
|
network, piped directly to the receive command or saved to a file. Each command
|
2024-05-11 07:46:58 +00:00
|
|
|
in the stream is protected by a CRC32C checksum, with 0 as the initial value
|
|
|
|
and no inversion. See :doc:`btrfs-send` and :doc:`btrfs-receive` for more,
|
|
|
|
for protocol description :doc:`dev-send-stream`.
|