繁体   English   中英

通过 ssh 传输后 rsync 挂起

[英]rsync hangs after transfer over ssh

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

我通过 ssh(来自文件服务器)使用 rsync 连接到远程服务器(我已经预先设置了共享的 rsa 密钥)。 当我运行以下行开始同步时,文件似乎都很好,但命令永远不会返回并且脚本永远挂起:

/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 开关,因为一些用户报告说这会导致挂起,但我没有看到任何区别。

编辑

再补充一点。 我今天再次运行脚本以继续进行故障排除。 如果我让脚本在挂起后继续运行而不打扰它,最终我会收到以下消息:

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]

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

更新

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

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

更新 2

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

我现在开始怀疑 ssh 连接是否超时或由于不活动而导致? 特别是因为在原始情况下,在进行大文件传输时,函数长时间没有任何输出。 这是一种可能的情况吗? 如果是这样,我该怎么做才能保持连接打开? (我不确定将 --progress 更新直接打印到日志文件是个好主意)。

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM