目录
一、rsync简介
(一)概念
- 一款快速增量备份工具
- Remote Sync,远程同步
- 支持本地复制,或者与其他SSH、rsync主机同步
官方网站:https://rsync.samba.org/
【1】rsync是一款开源的、快速的、多功能的、可实现全量及增量的本地或远程数据同步备份的优秀工具。并且可以不进行改变原有数据的属性信息,实现数据的备份迁移特性。
【2】rsync软件适用于unix/linux/windows等多种操作系统平台
【3】rsync是一个快速和非常同样的文件复制工具。它能本能复制,远程复制,或者远程守护进程方式复制,它提供了大量的参数来控制其行为的各个方面,并且允许非常灵活的方式来实现文件的传输复制
【4】以其delta-transfer算法闻名, rsync监听端口:873, rsync运行模式:C/S
(二)rsync同步源
1.指备份操作的远程服务器,也称为备份源
例:
A服务器同步B服务器的数据,B服务器就是备份源
反过来,B服务器同步A服务器的数据,那么A服务器就是备份源
(三)配置rsync源
1.基本思路
建立rsyncd.conf配置文件、独立的账号文件
启用rsync的 --daemon模式
2.配置文件rsyncd.conf
需要手动建立,语法类似与Samba配置
认证配置auth users、secrets file,不加则为匿名
3.rsync独立的账号文件
采用 “用户名:密码”的记录格式,每行一个用户记录
独立的账号数据,不依赖系统账号
4.启用rsync服务
通过 --daemon独自提供服务,rsync --daemon
执行kill $(cat /var/run/rsyncd.pid)关闭服务
rsync命令
(四)命令使用语法
1.语法格式
rsync [选项] 原始位置 目标位置
常用选项
-a :归档模式,递归并保留对象属性,等同于-rlptgoD
-v :显示同步过程的详细(verbose)信息
-z :在传输时进行压缩
-H:保留硬链接文件
-A:保留ACL属性信息
-delete 删除目标位置有而原始位置没有的文件
-checksum 根据对象的校验和来决定是否跳过文件
……
–delete的作用简单来说,就是删除差异文件,保留一致性
(五)同步方式
1.全量备份:
原有的数据全部传送
把原来的文件和新的文件一起统一传送
全量复制,效率低
2.增量备份
在传输数据之前通过一些算法通过你有的数据和我有的数据进行对比,把不一样的数据通过网络传输
增量复制,效率高
(六)实际操作
systemctl stop firewalld
setenforce 0
[root@localhost ~]#rpm -q rsync
rsync-3.0.9-18.el7.x86_64
[root@localhost ~]#vim /etc/rsyncd.conf
uid = nobody
gid = nobody
use chroot = yes
pid file = /var/run/rsyncd.pid
dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2
address = 192.168.56.100
port = 873
log file = /var/log/rsycd.log
hosts allow = 192.168.56.0/24
uid = nobody
gid = nobody
use chroot = yes
#禁锢在源目录
address = 192.168.100.41
#监听地址
port 873
#监听端口号 tcp/udp 873
log file = /var/log/rsyncd.log
#日志地址
pid file = /var/run/rsyncd.pid
#存放进程ID的文件位置
hosts allow = 192.168.56.0/24
#允许访问的客户机地址
[ftp]
#共享模块名称
path = /home/ftp
#原目录实际路径
comment = ftp export area
#备注
read only = yes
#是否只读
dont comperss = *.gz *.bz2 *.tgz *.zip *.rar *.z
#同步时不再压缩的文件类型
auth users = backuper
#授权账户,多个账号以空格分隔
secrets file = /etc/rsyncd_users.db
#存放账户信息的数据文件
[ftp]
path = /var/www/html
comment = web service
read only = yes
auth users = backuper
secrets file = /root/rsyncd_users.db
###如果采用匿名的方式,只要将其中的“auth users” 和“secrets file” 配置项去掉即可
[root@localhost ~]#vim /root/rsyncd_users.db
#为备份账户创建数据文件
backuper:123123
#建立同步用户
[root@localhost ~]#chmod 600 /root/rsyncd_users.db
###一定要600 权限
[root@localhost ~]#chmod +r /var/www/html
[root@localhost ~]#ls -ld /var/www/html
[root@localhost ~]#rsync --daemon
#守护进程后台运行
[root@localhost ~]# netstat -anpt |grep rsync
[root@localhost ~]# kill $(cat /var/run/rsyncd.pid)
################发起端(客户端)####################
[root@localhost mnt]#rsync -avz backuper@192.168.91.100::ky15 /mnt/
[root@localhost mnt]#rsync -avz rsync://backuper@192.168.56.100/ky15 /mnt
免交互配置:
echo "123123" > /etc/sever.pass
chmod 600 /etc/server.pass
crontab -e
30 22 * * * /usr/bin/rsync -az --delete --password-file=/etc/server.pass backuper@192.168.56.100::ky15 /mnt/
[root@localhost mnt]#echo "123123" >server.pass
[root@localhost mnt]#chmod 600 server.pass
[root@localhost mnt]#rsync -avz --password-file=/mnt/server.pass backuper@192.168.56.100::ky15 /mnt/
[root@localhost mnt]#crontab -e
30 23 * * * /usr/bin/rsync -az --password-file=/mnt/server.pass backuper@192.168.56.100::ky15 /mnt/
[root@localhost mnt]#crontab -l
二、rsync实时同步
使用inotify通知接口,可以用来监控文件系统的各种变化情况,如文件存取、删除、移动、修改等。利用这一机制,可以非常方便地实现文件异动告警、增量备份,并针对目录或文件的变化及时作出响应。
将inotify机制与rsync相结合,可以实现触发式备份(实时同步),即只要原始位置的文档发生变化,则立即启动增量备份操作;否则处于静默等待状态。这样,就避免了按固定周期备份时存在的延迟性、周期过密等问题。
因为inotify通知机制由 Linux内核提供,因此主要做本机监控,在触发式备份中,应用时更适合上行同步。
[root@localhost ~]#vim /etc/rsyncd.conf
read only = no
#修改只读模式为no
[root@localhost ~]#ss -ntap |grep rsync
[root@localhost ~]#kill 进程号
[root@localhost ~]#chmod 777 /var/www/html/
[root@localhost ~]#ll -d /var/www/html/
drwxrwxrwx. 3 root root 68 12月 12 23:22 /var/www/html/
调整inotify内核参数
max_queue_events:监控队列大小 默认16384
max_user_instances:最多监控实例数 默认 128
max_user_watches:每个实例最多监控文件数 默认8192
[root@localhost ~]#cat /proc/sys/fs/inotify/max_queued_events
16384
[root@localhost ~]#cat /proc/sys/fs/inotify/max_user_instances
128
[root@localhost ~]#cat /proc/sys/fs/inotify/max_user_watches
8192
cat /proc/sys/fs/inotify/max_user_instances
cat /proc/sys/fs/inotify/max_user_watches
cat /proc/sys/fs/inotify/max_queued_events
[root@localhost ~]# vi /etc/sysctl.conf
……
fs.inotify.max_queued_events = 32768
fs.inotify.max_user_instances = 1024
fs.inotify.max_user_watches = 1048576
[root@localhost ~]# sysctl -p
#####安装inotify#####
安装inotify-tools辅助工具
inotifywait:用于持续监控,实时输出结果(增删改属性修改)
inotifywatch:用于短期监控,任务完成后再出汇总结果
[root@localhost opt]#tar xf inotify-tools-3.14.tar.gz
[root@localhost opt]#cd inotify-tools-3.14/
[root@localhost inotify-tools-3.14]#./configure
[root@localhost inotify-tools-3.14]#make && make install
##开启 两个客户端
[root@localhost inotify-tools-3.14]#mkdir /var/www/html -p
[root@localhost inotify-tools-3.14]#cd /var/www/html/
##可以先执行“inotifywait”命令,然后另外再开启一个新的终端向 /var/www/html 目录下添加文件、移动文件,在原来的终端中跟踪屏幕输出结果。
[root@localhost ~]# inotifywait -mrq -e modify,create,move,delete /var/www/html
-e 用来指定要监控哪些事情
-m 表示持续监控
-r 表示递归整个目录
-q 简化输出信息
在另外一个终端编写触发式同步脚本
#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e create,delete,move,modify,attrib /var/www/html"
RSYNC_CMD="rsync -azH --delete --password-file=/root/server.pass /var/www/html backuper@192.168.56.100::ky15"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
if [ $(pgrep rsync | wc -l) -le 0 ] ; then
$RSYNC_CMD
# echo "${FILE} was rsynced" >>/opt/inotify_rsync.log
fi
done
[root@localhost ~]# chmod 777 /var/www/html/
[root@localhost html]#vim /opt/inotify.sh
#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e create,delete,move,modify,attrib /var/www/html"
RSYNC_CMD="rsync -azH --delete --password-file=/mnt/server.pass /var/www/html backuper@192.168.91.100::ftp"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
if [ $(pgrep rsync | wc -l) -le 0 ] ; then
$RSYNC_CMD
# echo "${FILE} was rsynced" >>/opt/inotify_rsync.log
fi
done
[root@localhost html]#chmod +x /opt/inotify
###去主节点
[root@localhost html]#rm -rf *
rsync可以快速删除大量文件
在主节点上 创建文件
[root@localhost html]#touch file{1..1000}.txt
[root@localhost opt]#rsync --delete-before -aHv --progress -stats /opt/ /var/www/html/
#找个空文件
三、总结
rsync的应用场景
1.增量同步
数据大、带宽小,rsync先压缩再传送,加速和保持速率
2.备份(辅助工具)
MySQL 主从复制,实际生产中很容易丢数据,并且同步量不完全一致,随着保存的数据量越来越大,会具有比较明显的差异性。可以结合rsync+inotify的方式来完成趋近于一致。
非高并发时可采用rsync+sersync来实现双向同步→MM架构(业务量不是特别大的情况)。
3.迁移
PS:一主、两从模式迁移方案
① 确定迁移的时间、业务线停止的时间、要写文档描述具体操作,发邮件审批
② 确认迁移后的节点的环境问题(资源环境+系统的依赖环境+MySQL内部的格式环境→自增长(格式一致性))
③ rsync+inotify 持续同步
④ 编写回滚方案、测试
⑤ 提交检修申请,备注检修时间段