一款快速增量备份工具
rsync同步源
1、基本思路
2、应用示例
3、配置文件rsyncd.conf
4、rsync账号文件
5、启用rsync服务
rsync [选项] 原始位置 目标位置
●常用选项
服务端IP:192.168.150.154
客户端IP:192.168.150.156
iptables -F
setenforce 0
systemctl stop firewalld
vim /etc/rsyncd.conf ##修改内容如下所示
uid = nobody #用户名
gid = nobody #组信息
use chroot = yes
port 873
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
hosts allow = 192.168.150.0/24
[wwwroot] ##共享站点
path = /var/www/html ##站点目录
comment = www.kgc.cn ##域名信息
read only = yes ##只读
dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2 ##文件类型
auth users = backuper ##管理员用户名
secrets file = /etc/rsyncd_users.db ##用户名密码文件
vim /etc/rsyncd_users.db ##配置文件修改如所示
backuper:abc123 ##用户名和密码
chmod 600 /etc/rsyncd_users.db ##给文件添加权限
rsync --daemon ##开启服务
netstat -natp | grep rsync ##查看服务
yum install httpd -y
cd /var/www/html/
vim index.html ##创建网页文件
格式一:
rsync -avz backuper@192.168.150.154::wwwroot /opt/ //密码abc123
##文件同步成功
格式二:
rsync -avz rsync://backuper@192.168.150.154/wwwroot /opt/ //密码abc123
##文件同步成功
vim /etc/server.pass ##编辑配置文件
abc123 ##文件中保存密码
chmod 600 /etc/server.pass ##添加权限
rsync -az --delete --password-file=/etc/server.pass backuper@192.168.150.154::wwwroot /opt/abc
服务端IP:192.168.150.156
客户端IP:192.168.150.154
yum install httpd -y
rm -rf * ##删除所有网页文件
vim /etc/sysctl.conf
fs.inotify.max_queued_events = 16384
fs.inotify.max_user_instances = 1024
fs.inotify.max_user_watches = 1048576
sysctl -p ##启动
cd /opt
tar zxvf inotify-tools-3.14.tar.gz
cd inotify-tools-3.14/
yum install gcc gcc-c++ make -y ##安装工具包
./configure
make && make install ##编译并安装
inotifywait -mrq -e modify,create,move,delete /var/www/html/
##执行监控 -m:持续进行监控 -r:递归监控所有子对象 -q:简述输出信息 -e:指定要监控的事件类型
'//此时是一个持续性的状态' 另外在开启一个新的终端设置 监控的路径是/var/www/html
cd /var/www/html/
touch index.txt ##在目录中创建文件
inotifywait -mrq -e modify,create,move,delete /var/www/html/
##可以看出都是可以监控到的内容
##第一台服务器主机可以看到内容如下所示
/var/www/html/ CREATE index.txt
vim inotfiy.sh
#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e modify,create,attrib,move,delete /var/www/html/"
RSYNC_CMD="rsync -azH --delete --password-file=/etc/server.pass /var/www/html/ [email protected]::wwwroot/"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
if [ $(pgrep rsync | wc -l) -le 0 ] ; then
$RSYNC_CMD
fi
done
chmod +x inotfiy.sh ##增加执行权限
##上述脚本用来检测本机/var/www/html目录的变动情况,一旦有更新触发rsync同步操作,上传备份至服务器192.168.150.156的/var/www/html目录下。
vim /etc/rsyncd.conf
read only = no ##要是开了只读的配置,就不能写入
chmod 777 /var/www/html/ ##服务端和客户端都要设置权限
./inotfiy.sh
##打开源服务器的另一个窗口在/var/www/html目录下创建新的文件
touch 1.txt
touch 2.txt
touch 3.txt
ls /var/www/html/
##已经同步成功,实验结束