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
    • 最新
    • 标签
主页 / unix / 问题 / 463694
Accepted
Mark
Mark
Asked: 2018-08-21 11:05:59 +0800 CST2018-08-21 11:05:59 +0800 CST 2018-08-21 11:05:59 +0800 CST

停止 rsync 计划任务竞争条件(大目录,小时间间隔)

  • 772

平台信息:

OpenBSD 6.2 amd64

$ rsync --version rsync version 3.1.2 protocol version 31

我正在尝试使用以下daily.local文件同步一个大目录(4TB)(对于 Linux 管理员,这本质上是一项 cron 日常任务):

#!/bin/sh
# Sync the primary storage device to the backup disk
/usr/local/bin/rsync -avz /mnt/media_primary/ /mnt/media_backup/

初始 rsync 复制需要一天多的时间。一两天后,我的进程列表中出现了多个运行的 rsync 副本:新进程按计划启动,这些新进程似乎相互竞争并且没有完成任务(至少很快)!

有没有办法让一个新的 rsync 进程知道其他 rsync 进程(或另一种避免 rsync 竞争条件的方法)?

我知道我可以手动运行 rsync 第一次复制目录和/或增加预定的时间间隔。这个问题更符合我的兴趣,因为我无法在网上找到有关此主题的信息。

backup rsync
  • 2 2 个回答
  • 781 Views

2 个回答

  • Voted
  1. Kusalananda
    2018-09-01T04:15:46+08:002018-09-01T04:15:46+08:00

    一种类似于Mark 的解决方案的解决方案,但不需要更改/etc/fstab或安装和卸载文件系统:

    #!/bin/sh
    
    lockdir=/tmp/file-copy.lock
    
    if ! mkdir "$lockdir"; then
       echo 'File copy already in progress' >&2
       exit 1
    fi
    
    trap 'rmdir "$lockdir"' EXIT
    
    PATH=$PATH:/usr/local/bin
    
    rsync -ai ...
    

    关于这一点的几点说明:

    1. 是mkdir一个原子操作,很像mount,如果目录已经存在,它将失败,但如果不存在则创建目录。这比首先检查锁定文件然后创建它(两个步骤之间可能存在竞争条件)更安全。

    2. EXIT陷阱确保脚本终止时删除锁定目录。锁定目录也将在重新启动时(由系统)删除,因为它位于/tmp.

    3. 我设置PATH为适当的值,而不是rsync使用其完整路径调用。这纯粹是一种装饰性的东西,但如果稍后将脚本扩展为使用 OpenBSD 端口集合中的其他命令(例如restic或borgbackup),这可能会很有用。

    4. 仅在非常慢的网络连接时才需要该-z选项(当压缩/解压缩数据比网络带宽更快时),并且从不用于本地复制。我也倾向于使用( ) 而不是( ),因为这会告诉我文件传输的确切原因。rsync-i--itemize-changes-v--verbose

    为了安全备份大量数据,我一般会推荐使用专门编写的备份软件rsync,例如restic或borgbackup。这两个额外进行重复数据删除和加密,并且borgbackup可以选择进行压缩。restic从某种意义上说是好的,它允许将备份保存到外部服务器(例如sftp),即使该服务器尚未restic安装,而borgbackup需要在目标系统上安装该软件。两者都restic处理borgbackup备份存储库锁定。

    • 3
  2. Best Answer
    Mark
    2018-09-01T04:02:20+08:002018-09-01T04:02:20+08:00

    解决这个问题的一种方法(如果备份目录在它自己的分区上)是让卷不挂载,在启动 rsync 命令之前挂载。这消除了使用的需要,flock并且可能具有延长驱动器寿命/降低功耗的好处。

    /etc/fstab:将noauto选项添加到分区,使其不会在启动时自动挂载

    在daily.local或cron.daily计划任务中:

    #!/bin/sh
    mount /mnt/media_backup && \
    /usr/local/bin/rsync -avz /mnt/media_primary/ /mnt/media_backup/ && \
    umount /mnt/media_backup
    

    双与号运算符 ( &&) 将仅在前一个命令成功时启动下一个命令。因此,如果无法挂载备份磁盘(因为它已经挂载并且 rsync 已经在分区上运行),则命令的其余部分将不会继续。

    • 1

相关问题

  • tar 目录只发送修改过的文件块

  • 如何复制具有相对重复符号链接的目录树?

  • 我可以将时移快照保存到保管箱吗?

  • rsync 排除问题

  • rsync 端口 22 和 873 使用

Sidebar

Stats

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

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve