🐼
rsync(Remote Sync)
rsync同步源
配置rsync同步源
rsync命令、选项、使用方法
rsync 【选项】原始位置 目标位置
配置源的表达方式
inotify
配置rsync下行同步
master
将master服务器数据备份到slave服务器
systemctl stop firewalld.service
setenforce 0
yum -y install httpd rsync
用/var/www/html/作为同步,所以安装httpd
vim /etc/rsyncd.conf
uid = nobody
gid = nobody
use chroot = yes
address = 172.16.10.116
port 873
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
hosts allow = 172.16.10.0/24
[wwwroot]
path = /var/www/html
comment = Document Root of www.qqq.com
read only = yes
dont comperss = *.gz *.bz2 *.tgz *.zip *.rar *.z
auth users = owo
secrets file = /etc/rsyncd_users.db
默认comment = Document Root of www.example.com
uid,gid = root 不修改可能会报错
编辑用户账号文件
vim /etc/rsyncd_users.db
文件赋权,必须为600
chmod 600 /etc/rsyncd_users.db
开启服务,检测端口
rsync --daemon
netstat -natp | grep rsync
切换目录到共享的目录下,并创建新的文件
cd /var/www/html
slave
关闭防火墙,安装rsync
systemctl stop firewalld.service
setenforce 0
yum -y install rsync
opt目录下创建一个目录,给予777权限
编辑免交互文件,密码,并赋予600权限
vim /etc/server.pass
rsync -az --delete --password-file=/etc/server.pass owo@172.16.10.116::wwwroot /opt/test1
rsync使用owo用户将172.16.10.116的共享模块压缩、归档,同步到当前服务器的opt/test1目录下删除差异内容
同步成功
rsync+inotify实时同步
master
为了写入要把只读模式关闭
vim /etc/rsyncd.conf
根据进程号杀死进程达到关闭服务的效果
之后再开启服务
确认作为共享目录的权限/var/www/html
chmod 777 /var/www/html
slave
查看当前默认的inotify内核参数
cat /proc/sys/fs/inotify/max_queued_events
cat /proc/sys/fs/inotify/max_user_instances
cat /proc/sys/fs/inotify/max_user_watches
在opt目录中放入安装包
解压
tar zxvf inotify-tools-3.14.tar.gz
cd /opt/inotify-tools-3.14/
./configure
make && make install
编辑自动监控同步脚本
持续监控
服务未启动,执行同步
vim /opt/inotify.sh
#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e create,delete,move,modify,attrib /opt/test1/"
RSYNC_CMD="rsync -azH --delete --password-file=/etc/server.pass /opt/test1/ owo@172.16.10.116::wwwroot"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
if [ $(pgrep rsync | wc -l) -le 0 ] ; then
$RSYNC_CMD
fi
done
赋予脚本执行权限,并后台执行
chmod +x inotify.sh
./inotify.sh &
验证
创建一个新的文件,删除之前的123.html
master