只有有了新的需求,才可以激发相应的动力去做事情!

最新有个新的需求-- 需要在Linux同步文件夹 

我绘制了其逻辑图,如下:


因为源数据库服务器里面的内容是定时变化的,而我不可能每时每刻都将数据同步到各个服务器,而只能定时的将数据同步到目标服务器里面。


下面说下配置rsync的步骤:



下面这个是我根据参考文章修改后的,并且添加了一些我自己的经验总结。

说明:

操作系统:CentOS-6.7-x86_64-minimal.iso

源服务器:192.168.11.130, 该机安装时设定的用户名为 oldmtn2

目标服务器:192.168.11.128, 该机安装时设定的用户名为 oldmtn

目的:把源服务器上/root/ceshi/目录实下所有文件同步到目标服务器的/root/folder1/下

具体操作:

第一部分:在目标服务器192.168.11.128上操作

一、分别在两台在目标服务器安装Rsync服务端

1、关闭SELINUX

知识科普:SElinux是Linux安全加强工具。关闭用setenforce 0或者修改文件vim /etc/sysconfig/selinux 把SELINUX=enforcing 改为 SELINUX=disabled.linux防火墙用chkconfig iptables on 开机启动 service iptables start 打开防火墙规则。

vi /etc/selinux/config #编辑防火墙配置文件

#SELINUX=enforcing #注释掉

#SELINUXTYPE=targeted #注释掉

SELINUX=disabled #增加

:wq! #保存,退出

setenforce 0  #立即生效, 其实就是关闭Linux的安全加强工具。

2、开启防火墙tcp 873端口(Rsync默认端口)

如果不打开873端口的话,源服务器同步文件时将会出现"rsync: failed to connect to : No route to host"的错误。

vi /etc/sysconfig/iptables #编辑防火墙配置文件

-A INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j ACCEPT #打开873端口,这条规则要加在REJECT规则前

:wq! #保存,退出

/etc/init.d/iptables restart #最后重启防火墙使配置生效

这一步现在还有问题,因为提示我上面红色部分的代码有问题,所以我先把不开启防火墙吧。。

3、安装Rsync服务端软件

yum install rsync xinetd #安装

vi /etc/xinetd.d/rsync #编辑配置文件,设置开机启动rsync

disable = no #修改为no

:wq! #保存退出

/etc/init.d/xinetd start #启动(CentOS中是以xinetd来管理Rsync服务的

4、创建rsyncd.conf配置文件

vi /etc/rsyncd.conf #创建配置文件,添加以下代码

log file = /var/log/rsyncd.log #日志文件位置,启动rsync后自动产生这个文件,无需提前创建

pidfile = /var/run/rsyncd.pid  #pid文件的存放位置

lock file = /var/run/rsync.lock  #支持max connections参数的锁文件

secrets file = /etc/rsync.pass  #用户认证配置文件,里面保存用户名称和密码,后面会创建这个文件

motd file = /etc/rsyncd.Motd  #rsync启动时欢迎信息页面文件位置(文件内容自定义)

[test1] #自定义名称, 后面源服务器发送文件的时候需要知道这个test1

path = /root/folder1/ #rsync服务端数据目录路径,从test1接受的文件都存放到这个夹子里面

comment = test1 #模块名称与[test1]自定义名称相同

uid = root #设置rsync运行权限为root

gid = root #设置rsync运行权限为root

port=873  #默认端口

use chroot = no #默认为true,修改为no,增加对目录文件软连接的备份

read only = no  #设置rsync服务端文件为读写权限

list = no #不显示rsync服务端资源列表

max connections = 200 #最大连接数

timeout = 600  #设置超时时间

auth users = root #执行数据同步的用户名,可以设置多个,用英文状态下逗号隔开

hosts allow = 192.168.11.130  #允许进行数据同步的客户端IP地址,可以设置多个,用英文状态下逗号隔开

hosts deny = 192.168.21.254 #禁止数据同步的客户端IP地址,可以设置多个,用英文状态下逗号隔开

:wq!  #保存,退出

5、创建用户认证文件

vi /etc/rsync.pass #配置文件,添加以下内容

root:123456  #格式,用户名:密码,可以设置多个,每行一个用户名:密码,在这里设置后,

:wq!  #保存,退出

6、设置文件权限

chmod 600 /etc/rsyncd.conf  #设置文件所有者读取、写入权限

chmod 600 /etc/rsync.pass  #设置文件所有者读取、写入权限

7、启动rsync

/etc/init.d/xinetd start  #启动

service xinetd stop   #停止

service xinetd restart #重新启动

第二部分:在源服务器192.168.11.130上操作

一、安装Rsync客户端

1、关闭SELINUX

vi /etc/selinux/config #编辑防火墙配置文件

#SELINUX=enforcing #注释掉

#SELINUXTYPE=targeted #注释掉

SELINUX=disabled #增加

:wq! #保存,退出

setenforce 0 #立即生效

2、开启防火墙tcp 873端口(Rsync默认端口,做为客户端的Rsync可以不用开启873端口)

vi /etc/sysconfig/iptables #编辑防火墙配置文件

-A INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j ACCEPT  #打开873端口,这条规则要加在REJECT规则前

:wq! #保存,退出

/etc/init.d/iptables restart #最后重启防火墙使配置生效

3、安装Rsync客户端软件

whereis rsync   #查看系统是否已安装rsync,出现下面的提示,说明已经安装

rsync: /usr/bin/rsync /usr/share/man/man1/rsync.1.gz

yum install  xinetd  #只安装xinetd即可,CentOS中是以xinetd来管理rsync服务的

yum install rsync xinetd #如果默认没有rsync,运行此命令进行安装rsync和xinetd

vi /etc/xinetd.d/rsync #编辑配置文件,设置开机启动rsync

disable = no #修改为

/etc/init.d/xinetd start #启动(CentOS中是以xinetd来管理rsync服务的)

4、创建认证密码文件

vi /etc/passwd.txt  #编辑文件,添加以下内容

123456 #密码

:wq! #保存退出

chmod 600 /etc/passwd.txt #设置文件权限,只设置文件所有者具有读取、写入权限即可

5、测试源服务器192.168.11.130到两台目标服务器192.168.11.128之间的数据同步

mkdir /root/ceshi #在源服务器上创建测试文件夹,然后在源服务器运行下面2行命令

rsync -avH --port=873 --progress --delete  /root/ceshi/  root@192.168.11.128::test1 --password-file=/etc/passwd.txt

运行完成后,分别在两台目标服务器192.168.11.128上查看,在/root/folder/目录下有了192.168.11.130的/root/ceshi/文件夹下的所有内容,说明数据同步成功。





如果想要实时同步文件夹,请参考:http://blog.csdn.net/oldmtn/article/details/47948105






参考:

1. http://www.osyunwei.com/archives/7435.html

2. https://rsync.samba.org/

3.http://blog.sina.com.cn/s/blog_65f2d7050100v6dz.html


GitHub 加速计划 / li / linux-dash
10.39 K
1.2 K
下载
A beautiful web dashboard for Linux
最近提交(Master分支:2 个月前 )
186a802e added ecosystem file for PM2 4 年前
5def40a3 Add host customization support for the NodeJS version 4 年前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐