AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 976096
Accepted
Thorsten Schöning
Thorsten Schöning
Asked: 2019-07-22 06:03:03 +0800 CST2019-07-22 06:03:03 +0800 CST 2019-07-22 06:03:03 +0800 CST

忽略一些中间快照以增量方式发送 ZFS 快照是否安全?

  • 772

一些背景。

我正在使用ZREP相互复制两台服务器,每台服务器都包含一个 ZFS 池,其中包含两个数据集作为复制主机和两组作为复制目标。主集包含本地服务器的系统和 VirtualBox-VM,复制目标与另一个相同。

此外,我正在将每台服务器的所有主集备份到使用rsync. NAS 非常慢,备份需要几个小时才能成功,因此实施的方法是暂停 VM,创建一个快照,还原 VM,rsync然后从创建的快照运行。重要的是手动创建的快照没有遵循 ZREP 命名约定,rsync再次完成后直接销毁。起初,ZREP 继续并行运行,由cron.

问题。

但时不时会发生 ZREP 进入某种无法再同步的状态。为了解决这个问题,一位同事告诉我他需要删除快照并按照流程重新初始化 ZREP。通过最终不再让 ZREPrsync与我们自己的快照并行运行,这个问题得到了解决。

遗憾的是,我缺乏该错误的具体细节,并且该同事不再可用,但从他的描述看来,在复制主机和目标之间找到快照的共同祖先以增量同步时存在问题。我认为错误消息类似于以下内容:

cannot receive incremental stream: most recent snapshot of zfs-pool/vbox/tori does not match incremental source
cannot open 'zfs-pool/vbox/tori@zrep_0001b7': dataset does not exist

我对增量发送/接收如何工作的理解。

根据我对文档和其他 问题的理解,要成功地增量发送快照,发送主机和接收目标需要共享一个用作参数 1 的快照,zfs send并且该快照还需要是接收目标上的当前快照。

第二个参数是一个任意较新的快照,ZFS 使用它来计算一个快照主节点和目标快照的共同差异,并将这些差异发送到复制目标。因为两者共享同一个指定为参数 1 的快照,所以差异对目标有意义并且可以简单地按原样应用。

根据我的理解,这些论点-i要么-I导致发送一个包含主端计算的所有增量数据的逻辑快照,要么发送包含其增量更改的所有中间快照。因此,例如-i,总是会导致目标上的一个新快照,而-I可能会导致 N 个额外的快照。

在作为 arg 1 和 2 提供的内容之间创建和销毁中间快照zfs send -i应该没有任何问题,因为 ZFS 总是只计算这两个提供的参数之间的差异,而不关心任何其他中间快照。在 ZREP 的情况下,这在理论上意味着只要我不干扰 ZREP 管理的快照,无论是否在其操作期间创建了额外的快照,它都不应该有任何区别。仅仅因为特殊的 ZREP 快照始终可用,由 ZREP 管理并用于计算复制差异。所以理论上,另外创建快照rsync和备份应该不是问题。

这些假设正确吗?

非 ZREP 相关问题。

一般而言,忽略一些中间快照以递增方式发送 ZFS 快照是否安全?或者是否有必要将曾经创建的所有中间快照发送到复制目标以使网络不同步或其他东西?事物如何依赖于-ivs. -I?

zfs
  • 1 1 个回答
  • 1798 Views

1 个回答

  • Voted
  1. Best Answer
    Thorsten Schöning
    2019-07-23T01:59:29+08:002019-07-23T01:59:29+08:00

    是的,您仍然可以获得中间的所有数据,但您不能倒回到中间。

    如果您有快照的 1,2 和 3,而远程池只有快照 1,您可以给它快照 3 并跳过 2.. 它只是无法回滚到“2”状态。但数据仍然存在。

    快照描述了当时的情况。因此,远程池上缺少快照“2”,就像您在那个时间点从未拍摄过一样。它实际上不知道“2”快照以及当时的情况。

    如果您改变主意,则需要删除远程池上的快照“3”,然后才能发送“2”,然后再次发送“3”。

    https://www.reddit.com/r/zfs/comments/cfzdb3/is_it_safe_to_send_zfssnapshots_incrementally/euensuy/

    • 1

相关问题

  • 从现有目录创建 zfs 的正确方法?

  • 如何将 ZFS ACL 从一个文件克隆到另一个文件?

  • ZFS 在演示期间在舞台上失败。这是正常行为吗?

  • Sneakernet 作为备份策略有意义吗?

  • ZFS 与 XFS

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve