频道栏目
首页 > 资讯 > 浏览器 > 正文

[sersync+rsync]centos6.5远程文件同步部署记录

15-07-01        来源:[db:作者]  
收藏   我要投稿

针对本地文件的修改,自动同步到远程文件夹,远程备份很方面。研究了下大家的主流同步方案一般是
rsync+inotify和rsync+sersync, 我这里使用sersync的方案,当然大部分都是参照前人经验,感谢他们的无私。

概述

我这里的目的是为了远程同步mysql的备份文件,centos6.5 同步到另一台centos主机

使用rsync+sersync做实时同步时,用于推送文件 的服务器运行sersync服务,用于接收文件的服务器则运行rsync守护进程,简单来说就是sersync会利用rsync命令将文件推送到 rsync服务器,实际线上使用一般会把sersync作为主服务器,rsync作为镜像服务器,实现数据同步备份,web镜像等功能

所以两台机器都需要rsync, 然后有对应的写数据权限。

准备

操作系统 centos6.5 x86 rsync yum源 sersync2.5_64bit 推送源A 114.110.1.38 (ip均为实验伪造) 接收机B 114.110.1.37

把A机器上的一个目录下文件的变化同步到B机器上,两边文件保持一致。
接收机B selinux与iptables自行设置好,rsync的端口两边要配置一致,默认是873

操作

接收机

1、 查看rsync是否安装

[root@i-nzwxivja xjmysql]# rpm -aq|grep rsync
rsync-3.0.6-4.el5_7.1

如果没有安装 yum install -y rsync 就行了

2、 rsync配置

[root@i-nzwxivja xjmysql]# cat /etc/rsyncd.conf
uid = root
gid = root
use chroot =no
list = no
log file = /var/log/rsyncd.log
[rsyncmysql]
path=/data/backup/xjmysql
comment=rsyncmysql
ignore errors
read only=no
list=no
max connections=200
timeout=600
auth users=rsync
secrets file=/etc/rsync.pas
hosts allow=*
#host deny=0.0.0.0/0

secrets file 这个是配置同步的密码文件的。 [rsynctest] 这个是配置同步模块的名称,后面会用 path 是配置同步的目录 hosts allow 是允许同步的主机 这里是测试就没有限制 hosts deny 拒绝同步的主机

3、 创建同步的用户与密码的文件,即上图中的secrets file这个配置选项中的文件。/etc/rsync.passwd,同进要设置这个文件的权限为600

# echo "rsync:123456lzz" >> /etc/rsync.pas
# chmod 600 /etc/rsync.pas

4、 创建同步的目录:即上图中path配置选项中的目录

# mkdir /data/backup/xjmysql

5、 启动rsync

# rsync  --daemon --config=/etc/rsyncd.conf
# ps -ef|grep rsync
root     17521     1  0 16:39 ?        00:00:00 rsync --daemon --config=/etc/rsyncd.conf
root     17529 16947  0 16:39 pts/1    00:00:00 grep rsync

接着重启一下xinetd使得配置生效

# /etc/init.d/xinetd restart

这里是通过 xinetd 服务来重启rsync,也可以不用这种方式,如果没有可以用yum直接安装

6、 配置开机启动

# echo "rsync --daemon --config=/etc/rsyncd.conf" >> /etc/rc.d/rc.local

推送源

1、 先到sersync 官网的地址已经不能使用了,我从网上找了一份放到其他地址, github上的源码镜像
我把二进制包下载也放到了上面

# wget --no-check-certificate https://raw.githubusercontent.com/orangle/sersync/master/release/sersync2.5.4_64bit_binary_stable_final.tar.gz
# mkdir /usr/local/sersync
# mkdir /usr/local/sersync/conf
# mkdir /usr/local/sersync/bin
# mkdir /usr/local/sersync/log
# tar zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz
# cd GNU-Linux-x86/
# cp confxml.xml /usr/local/sersync/conf
# cp sersync2 /usr/local/sersync/bin

2、 创建密码文件,同B服务器一样,不过这个文件只要保存一个密码就行了,不用用户名,权限也是600

echo "123456lzz" >> /etc/rsync.pas
chmod 600 /etc/rsync.pas

3、 配置sersync,配置文件就是上第二步复制的confxml.xml这个文中,路径在/usr/local/sersync/conf中


# 设置本地IP和端口 # 开启DUBUG模式 # 开启xfs文件系统 # 同步时忽略推送的文件(正则表达式),默认关闭 # 设置要监控的事件 # 本地同步的目录路径 # 远程IP和rsync模块名 # rsync指令参数 # rsync同步认证 # 设置rsync远程服务端口,远程非默认端口则需打开自定义 # 设置超时时间 # 设置rsync+ssh加密传输模式,默认关闭,开启需设置SSH加密证书 # sersync传输失败日志脚本路径,每隔60会重新执行该脚本,执行完毕会自动清空。 # 设置rsync+crontab定时传输,默认关闭 # 设置sersync传输后调用name指定的插件脚本,默认关闭 # 插件脚本范例 # 插件脚本范例

4、 创建同步目录:

mkdir /home/data

5、 设置环境变量:

# echo "export PATH=$PATH:/usr/local/sersync/bin/" >> /etc/profile
# source /etc/profile

6、 启动sersync

sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml
#重启操作如下:
# killall sersync2 && sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml

7、 设置开机启动

# echo "sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml" >> /etc/rc.local

实验

启动了sersync服务之后

发送机

[root@MiWiFi-R1D data]# ls /home/data/
[root@MiWiFi-R1D data]# touch backup.sql
[root@MiWiFi-R1D data]# ls
backup.sql

接收机

[root@i-nzwxivja xjmysql]# ls /data/backup/xjmysql/
[root@i-nzwxivja xjmysql]#
[root@i-nzwxivja xjmysql]# ls
backup.sql

结论

可以看到文件很快的就被同步到远程机器上了,实验成功。

相关TAG标签
上一篇:mongodb的分布式集群(1、主从复制)
下一篇:查看tidaljob中调用的sp是否真的在运行
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站