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 / 问题 / 27397
Accepted
David Hicks
David Hicks
Asked: 2009-06-18 08:14:59 +0800 CST2009-06-18 08:14:59 +0800 CST 2009-06-18 08:14:59 +0800 CST

将 LVM 快照同步到备份服务器

  • 772

我有许多 Xen 虚拟机在许多 Linux 服务器上运行。这些 VM 将其磁盘映像存储在 Linux LVM 卷中,设备名称类似于 /dev/xenVG/SERVER001OS 等。我想定期备份这些磁盘映像,以便在需要时恢复虚拟机(LVM 设备已经在两台物理机器之间使用 DRBD 进行了镜像,我只是在这里更加偏执)。

我该怎么做?显然第一步是对 LVM 设备进行快照,但是我如何以最有效的方式将数据传输到备份服务器?我可以简单地复制整个设备,类似于:

dd if=/dev/xenVG/SERVER001OS | ssh administrator@backupserver "dd of=/mnt/largeDisk/SERVER001OS.img"

...但这会占用大量带宽。是否有类似 rsync 的工具用于在远程服务器之间同步整个磁盘块的内容?就像是:

rsync /dev/xenVG/SERVER001OS backupServer:/mnt/largeDisk/SERVER001OS.img

如果我正确理解了 rsync 的手册页,上面的命令实际上不会起作用(会吗?),但它显示了我的目标。我了解 --devices rsync 选项是复制设备本身,而不是这些设备的内容。在与远程服务器同步之前制作 VM 映像的本地副本不是一种选择,因为没有磁盘空间。

是否有一个方便的实用程序可以在块设备和远程服务器上的备份文件之间进行同步?如果必须,我可以写一个,但现有的解决方案会更好。我是否错过了为我执行此操作的 rsync 选项?

backup linux lvm virtual-machines rsync
  • 11 11 个回答
  • 38595 Views

11 个回答

  • Voted
  1. David Herselman
    2010-08-07T21:57:12+08:002010-08-07T21:57:12+08:00

    尽管 RSync 有“写入设备”和“复制设备”补丁,但它们仅适用于小图像 (1-2GB)。RSync 将花费很长时间在更大的图像上搜索匹配的块,并且它对 40GB 或更大的设备/文件几乎没有用处。

    我们使用以下内容执行每 1MB 的校验和比较,如果内容不匹配,则简单地复制内容。我们使用它通过公共互联网将美国虚拟主机上的服务器备份到英国的备份系统。很少的 CPU 活动和快照性能仅在几个小时后受到影响:

    创建快照:

    lvcreate -i 2 -L 25G /dev/vg_kvm/company-exchange -n company-exchange-snap1
    
    export dev1='/dev/mapper/vg_kvm-company--exchange--snap1';
    export dev2='/dev/mapper/vg_kvm-company--exchange';
    export remote='[email protected]';
    

    初始播种:

    dd if=$dev1 bs=100M | gzip -c -9 | ssh -i /root/.ssh/rsync_rsa $remote "gzip -dc | dd of=$dev2"
    

    增量夜间备份(仅发送更改的块):

    ssh -i /root/.ssh/rsync_rsa $remote "
      perl -'MDigest::MD5 md5' -ne 'BEGIN{\$/=\1024};print md5(\$_)' $dev2 | lzop -c" |
      lzop -dc | perl -'MDigest::MD5 md5' -ne 'BEGIN{$/=\1024};$b=md5($_);
        read STDIN,$a,16;if ($a eq $b) {print "s"} else {print "c" . $_}' $dev1 | lzop -c |
    ssh -i /root/.ssh/rsync_rsa $remote "lzop -dc |
      perl -ne 'BEGIN{\$/=\1} if (\$_ eq\"s\") {\$s++} else {if (\$s) {
        seek STDOUT,\$s*1024,1; \$s=0}; read ARGV,\$buf,1024; print \$buf}' 1<> $dev2"
    

    删除快照:

    lvremove -f company-exchange-snap1
    
    • 19
  2. Best Answer
    Balázs Pozsár
    2009-06-25T08:29:36+08:002009-06-25T08:29:36+08:00

    标准 rsync 缺少此功能,但在 rsync-patches tarball (copy-devices.diff) 中有一个补丁,可以从http://rsync.samba.org/ftp/rsync/下载 应用并重新编译后,您可以使用 --copy-devices 选项 rsync 设备。

    • 12
  3. womble
    2011-10-29T19:33:00+08:002011-10-29T19:33:00+08:00

    有兴趣专门使用 LVM 快照执行此操作的人可能会喜欢我的lvmsync工具,它读取快照中已更改块的列表并仅发送这些更改。

    • 11
  4. rkthkr
    2009-06-18T08:42:19+08:002009-06-18T08:42:19+08:00

    看看Zumastor Linux Storage Project ,它通过ddsnap工具使用二进制“rsync”实现“快照”备份。

    从手册页:

    ddsnap 提供块设备复制,因为它具有能够有效地保存多个同时快照的块级快照工具。ddsnap 可以生成两个快照之间不同的快照块列表,然后通过线路发送该差异。在下游服务器上,将更新的数据写入快照块设备。

    • 6
  5. rcoup
    2011-11-04T15:44:39+08:002011-11-04T15:44:39+08:00

    有一个名为blocksync的 python 脚本,它是一种通过 ssh 在网络上同步两个块设备的简单方法,只传输更改。

    • 将 blocksync.py 复制到远程主机上的主目录
    • 确保您的远程用户可以使用 sudo 或者自己是 root
    • 确保您的本地用户(root?)可以读取源设备和 ssh 到远程主机
    • 调用:python blocksync.py /dev/source user@remotehost /dev/dest

    我最近对它进行了破解以清理它并将其更改为使用与 rsync ( Adler-32 ) 相同的快速校验和算法。

    • 3
  6. James
    2009-06-25T09:00:56+08:002009-06-25T09:00:56+08:00

    请注意,具有 LVM 快照的系统的性能与快照数量成正比。

    例如lvm 快照的 Mysql 性能

    • 1
  7. Ophidian
    2009-06-25T09:37:26+08:002009-06-25T09:37:26+08:00

    如果您尝试使用 plain 尽量减少通过电线发送的空白空间量dd,您能否在将其通过管道传输到 ssh 之前将其传输到 gzip ?

    例如 dd if=/dev/xenVG/SERVER001OS | 压缩包| ssh 管理员@backupserver "dd of=/mnt/largeDisk/SERVER001OS.img.gz"

    • 1
  8. shodanshok
    2018-08-04T12:56:07+08:002018-08-04T12:56:07+08:00

    这是一个老问题,但没有人提到两个非常有用的工具来有效地同步两个块设备:

    • bdsync,它使用差异传输和补丁方法;

    • blocksync(在这里你可以找到我改进的版本),它使用了就地重写的方法。

    我强烈建议使用这两种工具并选择更适合您预期用途的工具。

    • 1
  9. David B
    2019-06-23T22:50:19+08:002019-06-23T22:50:19+08:00

    经过几年的搜索,我最近创建了一个用于在服务器之间同步 LVM 快照的工具。它旨在使用最少的 IO,并允许系统在同步发生时运行。

    它与 ZFS 发送/接收类似,同步 LVM 快照之间的差异,并使用精简配置,从而将性能影响降至最低。

    我想要反馈,所以请看一下。

    • 1
  10. Martin
    2013-08-28T22:07:13+08:002013-08-28T22:07:13+08:00

    除了大卫赫塞尔曼的回答- 以下脚本将同步到本地设备:

    perl -'MDigest::MD5 md5' -ne 'BEGIN{$/=\1024};print md5($_)' $dev2 |
      perl -'MDigest::MD5 md5' -ne 'BEGIN{$/=\1024};$b=md5($_);
        read STDIN,$a,16;if ($a eq $b) {print "s"} else {print "c" . $_}' $dev1 |
       perl -ne 'BEGIN{$/=\1} if ($_ eq"s") {$s++} else {if ($s) {
        seek STDOUT,$s*1024,1; $s=0}; read ARGV,$buf,1024; print $buf}' 1<> $dev2
    

    据我所知,这两个脚本首先发布在lists.samba.org 上。

    • 0

相关问题

  • IIS 6.0 (Windows Server 2003) 备份的最佳实践?

  • 10TB数据和3台服务器的备份解决方案

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

  • 最佳混合环境(OS X + Windows)备份?[关闭]

  • 如何从 SQL Server 2008 中的备份中排除索引

Sidebar

Stats

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

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +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