Linux服务器Rsync结合inotify同步文件

582 2023年04月05日 服务器

一、实现效果

服务器A:192.168.161.150 (分布服务器)(rsync客户端+inotify)
服务器B:192.168.161.151 (WEB服务器1)(rsync服务端)
服务器C:192.168.161.152 (WEB服务器2)(rsync服务端)

说明:服务器A有文件更新,自动同步到服务器B和C

二、配置部署

1、服务器B:192.168.161.151/服务器C:192.168.161.152

1) 安装相应软件


#安装rsync(centos7默认安装)
yum -y install rsync  

2) 修改配置


 #建立数据同步存放目录
mkdir -p /www/wwwroot/rsync   
 #修改权限,必须要有读,写,执行权限,否而会失败。
chmod 755 /www/wwwroot/rsync   
#修改所属
chown nobody.nobody /www/wwwroot/rsync  

3) 修改配置文件,vim /etc/rsyncd.conf


uid = nobody
gid = nobody
use chroot = no
max connections = 10
strict modes = yes
log file = /www/server/rsync/log/rsyncd.log
pid file = /www/server/rsync/rsyncd.pid
lock file = /www/server/rsync/rsync.lock
secrets file = /www/server/rsync/rsyncd.secrets
read only = no
hosts allow = 192.168.161.150
list = yes
use chroot = no

[web1]

path = /www/wwwroot/rsync/ comment = web1 file auth users = rsync

4) 设置密码文件,防火墙


echo "rsync:12345678" > /www/server/rsync/rsyncd.secrets
#一定给600,其他权限错误
chmod 600 /www/server/rsync/rsyncd.secrets 
#一定记得要开启rsync
rsync --daemon --config=/etc/rsyncd.conf    
echo "rsync --daemon --config=/etc/rsyncd.conf" >> /etc/rc.local
#rsync默认端口是873,设置防火墙永久允许
firewall-cmd --permanent --add-port=873/tcp    
firewall-cmd --reload

2、服务器A:192.168.161.150

1) 安装相应软件


#安装rsync(centos7默认安装)
yum -y install rsync  

#下载inotify-tool软件包
wget http://downloads.sourceforge.net/project/inotify-tools/inotify-tools/3.13/inotify-tools-3.13.tar.gz 
tar -zxvf inotify-tools-3.13.tar.gz  
cd inotify-tools-3.13       
./configure     
make && make install

2)开启rsync


  rsync --daemon 

3)创建密码文件


mkdir /www/server/rsync
#12345678为rsync服务端配置的用户名为rsync的密码
echo "12345678" > /www/server/rsync/rsync.passwd
chmod 777 /www/server/rsync/rsync.passwd

4) 编写监控脚本 vim notify_rsync.sh


#!/bin/bash
export PATH=/bin:/usr/bin:/usr/local/bin
SRC=/www/wwwroot/rsync/   #设置修改数据的目录
DEST1=web1  #pc1的模块名
Client1=192.168.161.151
User=rsync
Passfile=/www/server/rsync/rsync.passwd
[ ! -e $Passfile ] && exit 2
#wait for change
inotifywait -mrq --timefmt '%y-%m-%d %H:%M' --format '%T %w%f %e' \
--event modify,create,move,delete,attrib $SRC | while read line
do
echo "$line" > /var/log/inotify_web 2>&1
#同步数据到pc1,下面命令其实就是rsync -avz /web_data/ tom@192.168.0.230::web1,然后把输出结果记录在sync_web1中 
rsync -avz --delete --progress --password-file=$Passfile $SRC ${User}@$Client1::$DEST1 >> /var/log/sync_web1 2>&1

done &

三、总结优化

1、问题一:

@ERROR: chroot failed
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]

原因:服务器端的目录不存在或无权限,创建目录并修正权限可解决问题。

2、问题二:

@ERROR: auth failed on module tee
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]

原因:服务器端该模块(tee)需要验证用户名密码,但客户端没有提供正确的用户名密码,认证失败。
提供正确的用户名密码解决此问题。

3、问题三:

@ERROR: Unknown module ‘tee_nonexists'
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]

原因:服务器不存在指定模块。提供正确的模块名或在服务器端修改成你要的模块以解决问题。

评论

0 条评论
OBJUI公众号
热门文章
  • 使用Echarts画甘特图

    Echarts是一个非常强大的图表库, 下面我们来使用它来画甘特图,

  • go语言怎么连接mysql,并实现增删改查

    要使用Go语言连接MySQL,需要使用第三方库。常用的库包括: 这里以go-sql-driver/mysql为 […]

  • Beego实现JWT

    Beego是一个基于Go语言的Web框架,实现JWT认证可以通过beego的中间件机制来实现,下面是一个简单的 […]

  • beego实现模块化开发

    Beego 框架可以通过模块化开发来提高项目的可维护性和可扩展性,可以将一个大型的应用划分为多个模块,每个模块独立维护,有自己的控制器、视图和模型等。

  • go实现MD5

    在这个示例中,我们使用了Go标准库中的crypto/md5包来计算一个字符串的MD5值。首先,我们将字符串转换 […]

  • Linux服务器Rsync结合inotify同步文件

    一、实现效果 服务器A:192.168.161.150 (分布服务器)(rsync客户端+inotify) 服务器B:192.168.161.151 (WEB服务器1)(rsync服务端) 服务器C:192.168.161.152 (WEB服务器2)(rsync服务端) 说明:服务器A有文件更新,自动同步到服务器B和C

  • 使用Axios+PHP+JWT实现登录认证

    JWT(JSON Web Token),顾名思义就是可以在Web上传输的token,这种token是用JSON格式进行format的。它是一个开源标准(RFC7519),定义了一个紧凑的自包含的方式在不同实体之间安全的用JSON格式传输信息。

  • wordpress自定义配置

    在制作插件时,自定义的配置项是经常会遇到的。在左侧“配置”的常规菜单下添加配置以下代码可实现:

  • JavaScript中async和await的应用

    async和await是ES7中引入的关键字,用于简化Promise操作,提高Promise代码的可读性和理解性。它们结合使用可以使得异步调用不返回Promise对象,而直接把then回调函数的第一个形参result给返回出来,使代码更节俭,开发效率更高。

  • wordpress中使用事务处理

    修改Mysql引擎,因为InnoDB才支持事务