我对 BTRFS 很陌生。我设法对我的系统进行只读快照并将其发送/接收到外部驱动器(再次将其作为 rw 进行快照,以便我什至可以启动它):到目前为止一切都很好。我知道,为了做增量快照,我必须知道哪个是前一个快照:btrfs 当然需要知道它应该将当前快照链接到哪个快照(以节省磁盘空间)。我还知道,如果我想增量备份到之前的快照也必须存在于外部驱动器上(它们具有相同的 ID)。晶莹剔透。整个故事在这里得到了很好的解释: https ://fedoramagazine.org/btrfs-snapshots-backup-incremental/
我在某处读到,如果我删除链中的快照,所有后续快照都会被赋予新的 ID:这让我认为,如果我在内部驱动器上只保留最后一个前一个快照,我将无法再加入外部驱动器上的链。这是对的吗?如何将所有增量快照保留在外部驱动器上,而仅将最后一个快照保留在内部驱动器上?
要正确回答您的问题,重要的是首先解释一下如何
btrfs send/receive
工作。来自BTRFS 维基:在初始发送的情况下,会生成一个数据流,其中包含在新磁盘上重新创建子卷的
btrfs send
指令- 即基本上告诉它:创建目录;创建文件;将以下内容放入.btrfs receive
foo
foo/bar
foo/bar
在增量发送的情况下,
btrfs send
会将您要发送的快照与指定的父级进行比较,-p
并生成一个仅包含这两个子卷之间差异的流。btrfs receive
然后将首先从父子卷创建一个新快照 - 因此它必须存在于接收端 - 并根据指令流修改该快照 -即移至;删除;更新以下内容;...foo/bar
bar
foo/
bar
btrfs receive
通过其 UUID 标识要从中获取快照的正确子卷。您可以通过以下方式查看子卷的 UUIDbtrfs subvolume show
:btrfs receive
它具有原始子卷的Received UUID因此,您需要进行增量发送的是您要发送的子卷和接收端已经存在的“父”子卷。BTRFS 不关心任何连续的“链”或其他东西,删除子卷不会更改另一个子卷的 ID。
为了可靠地工作,您应该尊重以下几点:
btrfs send
- 无论是在发送端还是在接收端 - 但始终保留它们ro
。