使用BBCP来提高跨网数据传输速度

默北 系统管理使用BBCP来提高跨网数据传输速度已关闭评论15,402字数 1912阅读6分22秒阅读模式

背景介绍:
目前项目在美国东西部以及欧洲都有服务器节点,跨互联网的数据传输速度很不稳定,之前我们主要是通过SCP以及Rsync等方式进行数据传输的。
无意间发现了BBCP这个软件之后,经过测试,效果非常好,速度提升效果很明显,并且传输速度一直比较稳定,同时支持日志以及失败后重试等参数,非常不错。

参考资料:
http://www.slac.stanford.edu/~abh/bbcp/
http://pcbunn.cithep.caltech.edu/bbcp/using_bbcp.htm
https://www.olcf.ornl.gov/kb_articles/transferring-data-with-bbcp/文章源自运维生存时间-https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/

安装配置:文章源自运维生存时间-https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/

$ sudo wget http://www.slac.stanford.edu/~abh/bbcp/bin/amd64_rhel60/bbcp -O /usr/bin/bbcp
$ sudo chmod +x /usr/bin/bbcp
$ sudo wget http://www.slac.stanford.edu/~abh/bbcp/bin/amd64_rhel60/bbcp -O /usr/bin/bbcp
$ sudo chmod +x /usr/bin/bbcp
$ which bbcp
/usr/bin/bbcp
$ ssh west-ads1 which bbcp
/usr/bin/bbcp

创建测试文件:文章源自运维生存时间-https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/

$ cd dong
$ sudo dd if=/dev/zero of=/home/adsymp/dong/file.2g bs=1024M count=2
2+0 records in
2+0 records out
2147483648 bytes (2.1 GB) copied, 45.9129 s, 46.8 MB/s
$ ls -lh
total 2.0G
-rw-r--r-- 1 root root 2.0G Mar 4 06:40 file.2g

测试:文章源自运维生存时间-https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/

$ time bbcp -r -P 2 -V -w 8m -s 16 file.2g west-ads1:/home/adsymp/dong/
bbcp: Window size reduced to 245760 bytes.
bbcp: Indexing files to be copied...
bbcp: Copying 0 files in 0 directories.
Source sc2-admin1002.drawbrid.ge using initial send window of 18700
Target iad2-admin1002.drawbrid.ge using initial recv window of 87380
bbcp: Creating /home/adsymp/dong/file.2g
bbcp: 140304 06:46:12  0% done; 8.5 MB/s, avg 8.5 MB/s
bbcp: 140304 06:46:14  1% done; 6.9 MB/s, avg 7.5 MB/s
...
bbcp: 140304 06:51:46  99% done; 7.7 MB/s, avg 6.1 MB/s
bbcp: 140304 06:51:48  99% done; 3.3 MB/s, avg 6.1 MB/s
Source cpu=3.643 (sys=3.552 usr=0.091).
File /home/adsymp/dong/file.2g created; 2147483648 bytes at 6.0 MB/s
48 buffers used with 0 reorders; peaking at 0.
Source sc2-admin1002.drawbrid.ge using a final send window of 433840
Target cpu=15.149 (sys=14.505 usr=0.644).
Target iad2-admin1002.drawbrid.ge using a final recv window of 2298624
1 file copied at effectively 6.0 MB/s

real    5m42.236s
user    0m0.104s
sys     0m3.567s

$ time scp file.2g west-ads1:/home/adsymp/dong/
file.2g   100%   2048MB   2.1MB/s   16:06    

real    16m8.448s
user    0m43.497s
sys     0m7.548s

结论:
在上面的测试中,传输一个大小为2G的文件,使用BBCP耗时仅5分钟,而普通的SCP则耗时16分钟,速度提升超过60%。
更进一步的测试报告可以在这里看到:http://heylinux.com/en/?p=258
转自:http://heylinux.com/archives/2984.html文章源自运维生存时间-https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/ 文章源自运维生存时间-https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/

weinxin
我的微信
微信公众号
扫一扫关注运维生存时间公众号,获取最新技术文章~
默北
  • 本文由 发表于 19/04/2014 09:47:52
  • 转载请务必保留本文链接:https://www.ttlsa.com/system/use-bbcp-to-improve-inter-network-data-transfer-rate/
  • BBCP
  • scp