bash-scp在复制大文件时停顿

前端之家收集整理的这篇文章主要介绍了bash-scp在复制大文件时停顿前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
根据实验的需要,我将 MTU设置为8000.这样做之后,当我使用scp复制大文件时,它停止了0.00%.我试过scp -l或scp -C并打开/关闭tcp_sack,但仍然没有工作.实验结果比较我不能更改MTU大小.还有什么其他方法可以帮忙吗?
尝试一个全面的解决方案,因为根据您的情况可能会有几个问题和限制.

rsync的

我最喜欢的选项是:使用rsync不会给出这个问题,在我看来更有多功能,例如它会跟踪哪些文件已经在那里,所以如果连接断开它可以从哪里停止 – try the --partial flag tooamong other things.

代替

scp local/path/some_file usr@server.com:"/some/path/"

你可以做

rsync -avz --progress local/path/some_file usr@server.com:"/some/path/"

我已经测试了几次,当scp会给我同样的问题,它给了你 – 现在我只是使用rsync默认情况下.

限速

在这种情况下,MTU是固定的(而且这可能不是这个问题),而不是解决方案,但是如果这两个驱动器之间的连接速度较慢/不可靠,则设置速度限制可以减少TCP连接失速的延迟 – 以牺牲慢的转移为代价.
这是因为scp可以获取所有带宽,除非您以千位指定最大数据速率,如下所示:

scp -l 8192 local/path/some_file usr@server.com:"/some/path/"

doesn’t always work虽然

压缩选项

scp的-C选项可以通过speed up的转移,减少传输失速的可能性.

禁用TCP SACK

如OP和here所述.

sudo sysctl -w net.ipv4.tcp_sack=0

(or similar)

LAN卡MTU

再一次MTU fix,不一定是转让具体:

ifconfig eth0 mtu 1492

newer (Linux) systems

ip link set dev eth0 mtu 1492

其他

如果其他一切都失败,this列出了其中一些潜在的解决方案.

更奇特的hpn bug也可能是故障.

猜你在找的Bash相关文章