centos7.5安装和配置rsync+sersync实现服务器文件同步

背景介绍:

       公司有很多的系统应用和数据虚拟机,最近有段时间,会出现虚拟机出问题的事件,幸亏是应用服务器,不会花费太长时间,就能恢复;这个时候,我们想把现在的多个虚拟机的上配置文件和数据,实时做好备份,以防发生特殊情况。

软硬件配置:

centos7.5

inotify-tools-3.14

rsync-3.1.1

sersync2.5.4_64bit_binary_stable_final

备份服务器安装和配置说明:

      备份服务器只需要安装rsync;

1、安装rsync     

cd /usr/local
mkdir rsync
cd  rsync
tar -xvf rsync-3.1.1.tar.gz
cd rsync-3.1.1
./configure
make && make install

2、修改rsyncd.conf文件

# 创建run和log文件目录
cd /usr/local/rsync
mkdir {run,log}

# 修改配文件
vi /etc/rsyncd.conf

uid=root
gid=root

#最大连接数
max connections=36000

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

#定义日志存放位置
log file=/usr/local/rsync/log/rsyncd.log
pid file=/usr/local/rsync/run/rsyncd.pid
lock file=/usr/local/rsync/run/rsyncd.lock

#忽略无关错误
ignore errors = yes

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

#认证的用户名与系统帐户无关在认证文件做配置,如果没有这行则表明是匿名
auth users = rsync

#密码认证文件,格式(虚拟用户名:密码)
secrets file = /etc/rsync.pass

#这里是认证的模块名,在client端需要指定,可以设置多个模块和路径
[2205oa]
#自定义注释
comment  = back 192.168.2.205 oa
#同步到B服务器的文件存放的路径
path=/bak/2205oa/
#设置只有这个IP才能访问
hosts allow = 192.168.2.205

# 保存退出
:wq

#创建rsync认证文件  可以设置多个,每行一个用户名:密码,注意中间以“:”分割
echo "rsync:rsync" > /etc/rsync.pass

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

#启动服务器B上的rsync服务
rsync --daemon 

#监听端口873
netstat -an | grep 873
lsof -i tcp:873

COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
rsync   31445 root    4u  IPv4 443872      0t0  TCP *:rsync (LISTEN)
rsync   31445 root    5u  IPv6 443873      0t0  TCP *:rsync (LISTEN)

#设置rsync为服务启动项(可选)
echo "/usr/local/bin/rsync --daemon" >> /etc/rc.local

#要 Kill rsync 进程
#ps -ef|grep rsync|grep -v grep|awk '{print $2}'|xargs kill -9

#再次启动
/usr/local/bin/rsync --daemon

需要备份服务器安装和配置说明:

1、软件安装

#安装rsync,提前将rsync-3.1.1.tar.gz上传到/usr/local
cd /usr/local
tar zxf rsync-3.1.1.tar.gz
cd rsync-3.1.1
./configure
make && make install

#安装inotify-tools,提前将inotify-tools-3.14.tar.gz上传到/usr/local
cd /usr/local
tar zxf inotify-tools-3.14.tar.gz
cd inotify-tools-3.14
./configure
make && make install

#安装sersync,提前将sersync2.5.4_64bit_binary_stable_final.tar.gz上传到/usr/local
cd /usr/local
tar zxf sersync2.5.4_64bit_binary_stable_final.tar.gz
mv /usr/local/GNU-Linux-x86/ /usr/local/sersync
cd /usr/local/sersync
#配置下密码文件,因为这个密码是要访问服务器B需要的密码和上面服务器B的密码必须一致
echo "rsync" > /usr/local/sersync/user.pass
#修改权限
chmod 600 /usr/local/sersync/user.pass

#修改confxml.conf
vi /usr/local/sersync/confxml.xml

<?xml version="1.0" encoding="ISO-8859-1"?>
<head version="2.5">
    <host hostip="localhost" port="8008"></host>
    <debug start="false"/>
    <fileSystem xfs="false"/>
    <filter start="false">
        <exclude expression="(.*)\.svn"></exclude>
        <exclude expression="(.*)\.gz"></exclude>
        <exclude expression="^info/*"></exclude>
        <exclude expression="^static/*"></exclude>
    </filter>
    <inotify>
        <delete start="true"/>
        <createFolder start="true"/>
        <createFile start="false"/>
        <closeWrite start="true"/>
        <moveFrom start="true"/>
        <moveTo start="true"/>
        <attrib start="false"/>
        <modify start="false"/>
    </inotify>

    <sersync>
        <localpath watch="/root/2205oa"><!-- 这里填写需要备份服务器要同步的文件夹路径-->
            <remote ip="192.168.8.235" name="2205oa"/><!-- 这里填写备份服务器的IP地址和模块名-->
            <!--<remote ip="192.168.8.39" name="tongbu"/>-->
            <!--<remote ip="192.168.8.40" name="tongbu"/>-->
        </localpath>
        <rsync>
            <commonParams params="-artuz"/>
            <auth start="true" users="rsync" passwordfile="/usr/local/sersync/user.pass"/>
            <userDefinedPort start="false" port="874"/><!-- port=874 -->
            <timeout start="false" time="100"/><!-- timeout=100 -->
            <ssh start="false"/>
        </rsync>
        <failLog path="/usr/local/sersync/2205oa/log/rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execute once-->
        <crontab start="false" schedule="600"><!--600mins-->
            <crontabfilter start="false">
                <exclude expression="*.php"></exclude>
                <exclude expression="info/*"></exclude>
            </crontabfilter>
        </crontab>
        <plugin start="false" name="command"/>
    </sersync>

</head>

# 运行
nohup /usr/local/sersync/sersync2 -r -d -o /usr/local/sersync/confxml.xml >/usr/local/sersync/rsync.log 2>&1 &

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值