前言
1,192.168.10.1 服务端(被同步目录**/data/ftp**)
2,192.168.10.2 客户端(同步服务端的目录到本机的**/data/ftp**)
工作讲解
10.1服务端**/data/ftp**目录下的文件或目录权限等发生改变,不管是增删改,都同步到10.2客户端指定目录,实现实时同步。
部署环境搭建
一、客户端(192.168.10.2)
- 安装相关服务
yum install rsync -y
systemctl restart rsyncd.service
systemctl enable rsyncd.service
- 创建同步的目录存放位置
mkdir -p /data/ftp
二、服务端(192.168.10.1)
- 添加源,更新索引
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum clean all
yum makecache
- 安装服务
yum install -y rsync
yum install -y inotify-tools
- 编写脚本
mkdir -p /data/{ftp,shell}
vim /data/shell/rsync_file.sh
#!/bin/bash
echo 8192000 > /proc/sys/fs/inotify/max_user_watches
host=192.168.10.2 #客户端ip
path_=/data/ftp/ #本机需要同步的目录
/usr/bin/inotifywait -mrq --timefmt '%d/%m/%y %H:%M' --format '%T %w%f' -e modify,delete,create,attrib $path_ | while read file
do
rsync -avPz --delete --progress $path_ $host:$path_ >>/data/shell/rsync_file.log 2>&1
echo "${file} was rsynced" >>rsync.log 2>&1
done
- 编写启动服务
vim /usr/lib/systemd/system/rsync_file.service
[Unit]
Description = rsync_file
[Service]
Type=simple
WorkingDirectory=/data/shell/
ExecStart=/usr/bin/bash rsync_file.sh
ExecStop=/usr/bin/ps -ef | /usr/bin/grep "bash" | /usr/bin/grep "rsync_file.sh" | /usr/bin/awk '{print $2}' | /usr/bin/xargs/usr/bin/kill -9
User=root
Group=root
[Install]
WantedBy=multi-user.target
- 免密登入
ssh-keygen -t rsa #一直回车直到结束
scp .ssh/id_rsa.pub 192.168.10.2:/root/ #把id_rsa.pub私钥发给10.2
10.2在客户端服务器上(192.168.10.2)执行以下命令
cd
mkdir .ssh
cat id_rsa.pub > /root/.ssh/authorized_keys
chmod 700 .ssh
chmod 600 /root/.ssh/authorized_keys
10.1执行测试ssh是否正常部署,以下情况红线标记的表示ssh部署成功
10.1执行启动服务,验证是否实时同步,如果源**/data/ftp**原本有文件或目录,也会自动同步过去
systemctl enable rsync_file.service
systemctl restart rsync_file.service
查看同步日志,在**/data/shell**下,有 rsync_file.log rsync.log 两日志文件,这里就不截图了
完结
感谢老铁,运维有你!