通过 ssh 传输后 rsync 挂起

rsync hangs after transfer over ssh

我编写了一个 bash 脚本,用于将文件从网络服务器 (HostGator) 备份到本地文件服务器 运行ning FreeBSD。

我使用 rsync over ssh(从文件服务器)连接到远程服务器(我已经设置了预共享 rsa 密钥)。当我 运行 以下行开始同步时,文件似乎都正常,但命令永远不会 returns 并且脚本永远挂起:

/usr/local/bin/rsync -az --chown=root:admin --chmod=ugo=rwX --exclude ".inode_lock" --rsh='ssh -p2222' admin@domain.com:/home/admin/ '/mnt/blah/blah/LocalBackup/' >> "./Logs/Backup Log.txt"

等待几分钟后,当我按 Ctrl+C 停止命令时,我弹出以下错误消息:

^CKilled by signal 2.
rsync error: unexplained error (code 255) at rsync.c(636) [generator=3.1.2]
rsync error: received SIGUSR1 (code 19) at main.c(1429) [receiver=3.1.2]

即使双方已经同步并且它只是在检查更改,这仍然会发生。

我不确定如何解决问题。我确实尝试删除 rsync 的 -v 开关,因为一些用户报告说这会导致挂起,但我没有发现任何差异。

编辑

再补充一点。今天我运行重新脚本继续排查。如果我在脚本挂起后离开脚本 运行ning 而不打扰它,最终我会收到以下消息:

rsync: connection unexpectedly closed (2984632408 bytes received so far) [receiv    er]
rsync error: error in rsync protocol data stream (code 12) at io.c(226) [receive    r=3.1.2]
rsync: connection unexpectedly closed (8689703 bytes received so far) [generator    ]
rsync error: unexplained error (code 255) at io.c(226) [generator=3.1.2]

然后 returns 回到命令提示符。我认为这可能是由于远程服务器端超时但不确定。但是我仍然不确定为什么会发生挂起。

更新

我做了一个额外的测试,并将 rsync t运行sfer 限制到一个包含一些示例文件和子文件夹的特定测试文件夹,而不是抓取整个主目录。当我这样做时,它能够成功完成 t运行sfeer 并适当退出。因此看起来在导致问题的服务器的主目录中的某处必须有一些文件或文件夹。是否存在 rsync 无法 t运行sfer 文件的特定情况?我已经看到它在尝试同步写锁定的文件时抛出错误,并出现 "Permission Denied" 错误,但即使是这些文件也没有阻止它继续。有什么想法吗?

另外请注意,我要连接的远程服务器位于共享主机帐户上,因此我没有根访问权限。我不知道这是否会导致一些问题?

更新 2

所以我研究了 rsync 命令并添加了更多的命令行参数 --progress 和 --stats(以及 --verbose),这样我就可以更好地理解它在哪里死了。我现在注意到的是,当 运行 执行命令时,它挂在一个正在从服务器下载的非常大的文件上。但是现在报告了 --progress(我暂时将它直接输出到终端而不是文件),它似乎进展顺利,到目前为止没有挂断。

我现在开始怀疑可能是 ssh 连接超时或由于不活动造成的?特别是在原来的情况下,当大文件 t运行sfer 发生时,函数很长时间没有输出任何内容。这是可能的情况吗?如果是这样,我该怎么做才能保持连接打开? (我不确定将 --progress 更新直接打印到日志文件是个好主意)。

好的,我明白了。显然 HostGator 的共享服务器默认设置了 30-45 分钟的 SSH 超时限制。由于 运行 rsync 花费的时间超过了该限制,因此它正在关闭连接。我打电话给他们的技术支持并与他们交谈,他们为我的服务器增加了它。