背景介绍:
目前我们线上的前端服务器数量比较多,超过200多台,每次发布新应用的时候,都是将软件包放在一台专门的Push服务器上,再由所有的前端服务器通过rsync自动同步。但随着前端服务器的数量越来越多,Push服务器的带宽已经成为了瓶颈。

而BitTorrent Sync这种P2P方式的同步则是一种解决方案。同时它的跨平台支持也非常好,无论是Windows,Linux,Mac OS,甚至手机端都有相应的客户端。虽然目前尚未开源,但可以免费使用,还是很不错的。

下面,就是我们在线上的纯Linux测试环境中的安装与配置步骤:

Servers:
Master:idc2-server1
Slave:idc2-server2、idc2-server3

  1. 下载BitTorrent Sync,在所有服务器上
    $ sudo wget http://download-lb.utorrent.com/endpoint/btsync/os/linux-x64/track/stable -O /tmp/btsync_x64.tar.gz
    $ sudo mkdir /opt/btsync
    $ cd /opt/btsync
    $ sudo tar xzf /tmp/btsync_x64.tar.gz

  2. 创建服务管理脚本,在所有服务器上
    $ sudo vim /etc/init.d/btsync

    1. #!/bin/sh
    2. #
    3. # description: starts and stops the btsync client
    4.  
    5. CONF=/opt/btsync/btsync.cfg
    6. PROC=/opt/btsync/btsync
    7. PIDFILE=/opt/btsync/btsync.pid
    8.  
    9. start() {
    10. PID1=$(pidof btsync)
    11. if [ -z ${PID1} ]; then
    12. echo -n "Starting BitTorrent Sync: "
    13. ${PROC} --config ${CONF}
    14. else
    15. echo "BitTorrent Sync is already running at pid:${PID1}"
    16. fi
    17. return $?
    18. }
    19.  
    20. stop() {
    21. echo -n "Stopping BitTorrent Sync: "
    22. PID1=$(pidof btsync)
    23. if [ ! -z ${PID1} ]; then
    24. kill - ${PID1}
    25. echo "OK"
    26. else
    27. echo "Failed"
    28. fi
    29. return $?
    30. }
    31.  
    32. status() {
    33. PID1=$(pidof btsync)
    34. PID2=$(cat ${PIDFILE})
    35. echo -n "Checking BitTorrent Sync: "
    36. if [ ! -z ${PID1} ] && [ "${PID1}" -eq "${PID2}" ]; then
    37. echo "OK"
    38. else
    39. echo "Failed"
    40. fi
    41. return $?
    42. }
    43.  
    44. case "$1" in
    45. start)
    46. start
    47. ;;
    48. stop)
    49. stop
    50. ;;
    51. restart)
    52. stop
    53. sleep
    54. start
    55. ;;
    56. status)
    57. status
    58. ;;
    59. *)
    60. echo $"Usage: $0 {start|stop|restart|status}"
    61. exit
    62. esac

    btsync Code

    sudo chmod +x /etc/init.d/btsync

  3. 创建用于同步的目录,在所有服务器上
    sudo mkdir /opt/btsync_transfer

  4. 创建配置文件,在idc2-server1上
    sudo vim /opt/btsync/btsync.conf

    1. {
    2. "device_name": "idc2-server1",
    3. "listening_port" : , // 0 - randomize port
    4.  
    5. "check_for_updates" : false,
    6. "use_upnp" : false,
    7.  
    8. "storage_path" : "/opt/btsync",
    9. "pid_file" : "/opt/btsync/btsync.pid",
    10.  
    11. "download_limit" : , // 0 - no limit
    12. "upload_limit" : ,
    13.  
    14. "webui" :
    15. {
    16. "listen" : "0.0.0.0:8888",
    17. "login" : "admin",
    18. "password" : "btsync"
    19. }
    20.  
    21. ,
    22. "folder_rescan_interval" : ,
    23. "lan_encrypt_data" : false,
    24. "lan_use_tcp" : true
    25. }

    btsync.conf Code

  5. 创建同步所需的密钥,在idc2-server1上
    sudo /etc/init.d/btsync start
    打开Web UI:http://idc2-server1:8888
    用户名: admin
    密码: btsync

    点击 "Add Folder",
    在 "Path" 中输入 "/opt/btsync_transfer"
    点击 "Generate" 得到 "Secret" 为 "ALUORWDEWOLV354ZHPHFT4TSQO67JWQAN"
    如下图所示:

  6. 创建配置文件,在idc2-server2和idc2-server3上:
    sudo vim btsync.cfg

    1. {
    2. #定义设备名称,一般写主机名或者IP
    3. "device_name": "idc2-server2",
    4. #是使用随机端口还是固定端口,0表示随机
    5. "listening_port" : , // 0 - randomize port
    6.  
    7. #是否检查文件更新
    8. "check_for_updates" : false,
    9. #使用UPnP进行端口映射
    10. "use_upnp" : false,
    11.  
    12. #storage_path包含一些运行时产生的状态文件,如果没有定义,则会在二进制命令运行的目录下产生一个.sync隐藏目录
    13. "storage_path" : "/opt/btsync",
    14. #定义pid文件的路径
    15. "pid_file" : "/opt/btsync/btsync.pid",
    16.  
    17. #是否对上传/下载进行限速,0表示不限速
    18. "download_limit" : , // 0 - no limit
    19. "upload_limit" : ,
    20. "webui" :
    21. {
    22. #如果去掉listen项,则表示禁用WEB UI
    23. "listen" : "0.0.0.0:8888",
    24. "login" : "admin",
    25. #如果去掉login/password,则表示不用验证
    26. "password" : "btsync"
    27. }
    28. ,
    29.  
    30. #如果你在配置文件中设置了shared folders,则WEB UI中的会被禁止,配置文件中的会覆盖UI中设置的。
    31. "shared_folders" :
    32. [
    33. {
    34. #你的secret,可以使用--generate-secret参数生成
    35. "secret" : "ALUORWDEWOLV354ZHPHFT4TSQO67JWQAN", // * required field
    36. #同步的目录
    37. "dir" : "/opt/btsync_transfer", // * required field
    38. #是否自动删除文件
    39. "use_sync_trash" : false
    40. #是否使用中继服务器
    41. "use_relay_server" : true,
    42. #是否使用tracker服务器
    43. "use_tracker" : true,
    44. "search_lan" : true,
    45. #设置不用查找就可以直接连接的机器
    46. "known_hosts" :
    47. [
    48. "idc2-server1:8889"
    49. ]
    50. }
    51. ]
    52. ,
    53. "folder_rescan_interval" : ,
    54. "lan_encrypt_data" : false, // Encryption is very painful in terms of speed. Disabling it for LAN to increase the speed.
    55. "lan_use_tcp" : true
    56. }

    btsync.cfg Code

    sudo /etc/init.d/btsync start
    idc2-server3 同 idc2-server2设置,只需更改IP、主机名即可

  7. 在/opt/btsync_transfer中放置一些文件,就可以查看同步的状态了
    打开Web UI:http://idc2-server1:8888
    #将示例配置文件保存到当前目录下:
    ./btsync –dump-sample-config > sync.conf
    #启动btsync服务
    ./btsync –config sync.conf

  8. 注意事项
    如果是选择只读同步(服务器->本地),在文件传送完毕后如果不想再同步,记得在本地客户端上删除同步的目录,否则容易出现服务器端删除了文件,本地也会自动的删除该文件的情况。当然,读写同步更是如此。

    参考资料:

    http://heylinux.com/archives/2917.html

    http://my.oschina.net/guol/blog/202002

在 Linux 上安装配置 BitTorrent Sync [转]的更多相关文章

  1. linux上安装配置samba服务器

    linux上安装配置samba服务器 在linux上安装配置samba服务器 在这给大家介绍一个不错的家伙,samba服务.如果您正在犯愁,如何在Windows和Linux之间实现资源共享,就请看看这 ...

  2. Linux上安装配置Keepalived

    Linux上安装配置Keepalived 1.下载 自行去Keepalived官网进行下载,也可以通过如下链接进行下载2.0.18版本(目前的稳定版) 链接:https://pan.baidu.com ...

  3. linux 上安装配置l2tp的客户端

    有些时候我们外网linux服务器需要访问内网的服务器,这时候就需要在外网服务器上配置l2tp的客户端,连接到VPN访问内网服务器. 安装: yum -y install xl2tpd ppp 安装成功 ...

  4. Ubuntu Linux上安装配置Mysql

    一.安装: 三种安装方式: 1. 从网上安装 sudo apt-get install mysql-server.装完已经自动配置好环境变量,可以直接使用mysql的命令. 注:建议将/etc/apt ...

  5. linux上安装配置vsftpd(转)

    转自:http://www.webarch.org/category/linux生产环境是Centos5.6,由于需要提供ftp服务,就找了一款比较小巧的ftp服务器端软件,vsftpd(vsftpd ...

  6. linux上安装配置vsftpd

    启动: /usr/sbin/vsftpd & 端口占用: lsof -i:21 位置: whereis vsftpd 默认配置下,匿名用户登录 vsftpd 服务后的根目录是 /var/ftp ...

  7. redis3.0.5在linux上安装与配置

    redis3.0.5在linux上安装与配置 rhel6/ubuntu14 1 下载 # wget http://download.redis.io/releases/redis-3.0.5.tar. ...

  8. Linux上安装jdk1.8和配置环境变量

    前言 Linux 上安装jdk1.8 和配置环境变量,参考相关文档,本人在此总结,操作归纳如下. 第一步:创建jdk安装目录(该/usr/local/src 目录是空的,最好把我们自己下载的放到这,容 ...

  9. 阿里云服务器Linux CentOS安装配置(九)shell编译、打包、部署

    阿里云服务器Linux CentOS安装配置(九)shell编译.打包.部署 1.查询当前目录以及子目录下所有的java文件,并显示查询结果 find . -name *.java -type f - ...

随机推荐

  1. mvn打包到私服的命令

    1.mvn clean package install -Dmaven.test.skip=true deploy 2.docker清楚Nexus私服上包的命令: a) docker exec -it ...

  2. BZOJ4860 BJOI2017 树的难题 点分治、线段树合并

    传送门 只会线段树……关于单调队列的解法可以去看“重建计划”一题. 看到路径长度$\in [L,R]$考虑点分治.可以知道,在当前分治中心向其他点的路径中,始边(也就是分治中心到对应子树的根的那一条边 ...

  3. Mac安装使用MongoDB

    Mac 下安装 MongoDB 一般有两种方法,一种是通过源码安装,一种是直接使用 homebrew ,个人推荐使用 homebrew ,简单粗暴. 一.安装 homebrew : /usr/bin/ ...

  4. (转)对一个deb包的解压、修改、重新打包全过程方法

    转自:https://blog.csdn.net/yygydjkthh/article/details/36695243 Reference: http://www.debian.org/doc/ma ...

  5. Linux/CentOS下安装MySql RPM Bundle

    一.下载对应的版本的MySql安装文件 1.下载路径 https://dev.mysql.com/downloads/mysql/ 2.选择对应的Linux版本和x86/x64位的安装文件 查看Lin ...

  6. ORA-00020:maximum number of processes (150) exceeded

    异常的含义 超过最大的进程数 我们使用下面的语句可以查看与进程(process)的相关参数: 如上所示,这里的最大进程数是150. 问题可能存在的原因 1.应用程序在使用数据库连接池时,使用完成后没有 ...

  7. Android自动化测试之:获取 参数:comonentName 的值方法

    十年河东十年河西,莫欺少年穷! 不了解Activity的,可参考:http://www.cnblogs.com/tekkaman/archive/2011/06/07/2074211.html 相关代 ...

  8. Luogu P2403 [SDOI2010]所驼门王的宝藏

    比较显然的缩点+拓扑排序题,只不过要建虚点优化建边. 首先我们发现在一个SCC里的点都是可以一起对答案产生贡献的,因此先缩成DAG,然后拓扑找最长链. 但是我们发现这题最坏情况下边数会达到恐怖的\(O ...

  9. 基于uFUN开发板的RGB调色板

    前言 使用uFUN开发板配合Qt上位机,实现任意颜色的混合,Qt上位机下发RGB数值,范围0-255,uFUN开发板进行解析,然后输出不同占空比的PWM,从而实现通过RGB三原色调制出任意颜色. Qt ...

  10. CentOS搭建V~P~N服务,实现虚拟专用网络

    什么是V-P-N V-P-N即虚拟专用网络,它的功能是:在公用网络上建立专用网络,进行加密通讯. V-P-N网关通过对数据包的加密和数据包目标地址的转换实现远程访问.V-P-N有多种分类方式,主要是按 ...