Rsync数据备份工具
1、Rsync简介
Rsync是一款开源的数据备份工具,可以用于不同主机之间同步传输数据,可以实现全量备份和增量备份。
Rsync监听端口:
Rsync工具默认运行在TCP的873端口。
Rsync工作模式:
Rsync三种工作模式:
1.本地模式:不常用,类似cp命令;
2.远程模式:常用,在不同主机之间传输数据;
3.后台服务模式:常用,用于实时同步数据,安全性高。
2、数据备份简介
2.1 数据备份方式
从备份方式来说,数据备份有两种备份方式:
1.全量备份
2.增量备份
全量备份:
完全备份,将客户端所有数据内容全部备份至服务端(效率低下,占用空间)。
增量备份:
增量备份,将客户端数据和服务端数据对比,只备份客户端新增加或者改变的数据至服务端(提高备份效率,节省空间,适合异地备份)。
2.2 数据备份架构
- 数据推送(上传):所有主机推送本地数据至Rsync备份服务器,会导致数据同步缓慢(适合少量数据备份)。
- 数据拉取(下载):所有主机从Rsync备份服务器,拉取备份数据到本地。
- 大量服务器数据备份场景。
- 异地备份场景。
3、Rsync本地模式和远程模式
3.1 安装Rsync工具
安装命令:
#环境准备
client服务器:10.0.0.15
server服务器:10.0.0.16
#客户端和服务端都需要安装Rsync工具
yum -y install rsync
3.2 rsync命令选项
-a #归档模式传输,等于-tropglD
-v #详细模式输出,显示速率,文件数量等
-z #传输时进行压缩,提高效率
-r #递归传输,传输目录,传输目录时目录名称后加"/"表示传输目录下的所有文件
-t #保持文件时间信息
-o #保持文件属主信息
-g #保持文件属组信息
-p #保持文件权限
-l #保留软链接
-D #保持设备文件信息
-P #显示同步的过程及传输时的进度等信息
-L #保留软连接指向的目标文件
--delete #让目标目录和源目录数据保持一致
--bwlimit #限速传输
--exclude=PATTERN #指定排除不需要传输的文件模式
--exclude-from=FILE #排除FILE中指定模式的文件
3.3 本地模式用法
rsync [OPTION...] SRC... [DEST]
#备份本地文件至其他位置
[root@client ~]# touch file1
[root@client ~]# rsync -avz file1 /tmp/
sending incremental file list
file1
sent 83 bytes received 35 bytes 236.00 bytes/sec
total size is 0 speedup is 0.00
[root@client ~]# ls /tmp/
crontab.gjp7fs
file1
ks-script-nc4wzV
systemd-private-a5efc68639ea4045a00fd333479c44be-vgauthd.service-QyLl51
systemd-private-a5efc68639ea4045a00fd333479c44be-vmtoolsd.service-KUA16O
systemd-private-bdfee1d0d79e4d4c83528124b59af5ac-vgauthd.service-yWorJ2
systemd-private-bdfee1d0d79e4d4c83528124b59af5ac-vmtoolsd.service-SBKSbM
yum.log
#备份目录时,使目标目录与源目录数据保持一致;若目标目录有多余的文件则会被删除
[root@client ~]# mkdir hzz
[root@client ~]# touch hzz/hzz{1..2}
[root@client ~]# rsync -avz /root/hzz /tmp/
sending incremental file list
hzz/
hzz/hzz1
hzz/hzz2
sent 163 bytes received 58 bytes 442.00 bytes/sec
total size is 0 speedup is 0.00
[root@client ~]# ls /tmp/hzz/
hzz1 hzz2
[root@client ~]# touch /tmp/hzz/hzz3
[root@client ~]# ls /tmp/hzz/
hzz1 hzz2 hzz3
[root@client ~]# rsync -avz --delete /root/hzz /tmp/
sending incremental file list
deleting hzz/hzz3
sent 88 bytes received 29 bytes 234.00 bytes/sec
total size is 0 speedup is 0.00
[root@client ~]# ls /tmp/hzz/
hzz1 hzz2
3.4 远程模式用法
rsync [OPTION...] [USER@]HOST:SRC... [DEST]
rsync [OPTION...] SRC... [USER@]HOST:DEST
#将本地文件备份至其他主机
[root@client ~]# rsync -avz file1 root@10.0.0.16:/root/
The authenticity of host '10.0.0.16 (10.0.0.16)' can't be established.
ECDSA key fingerprint is SHA256:rTf+awJf/okAhV+47f4pbkueWtE//bqfsTNJmzaw0Rg.
ECDSA key fingerprint is MD5:7a:3e:15:3a:6f:d3:9f:5c:25:d2:73:ae:a2:4c:0b:da.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '10.0.0.16' (ECDSA) to the list of known hosts.
root@10.0.0.16's password:
sending incremental file list
file1
sent 83 bytes received 35 bytes 15.73 bytes/sec
total size is 0 speedup is 0.00
[root@server ~]# ls
anaconda-ks.cfg file1
#将其他主机文件备份至本地
[root@client ~]# rm -rf file1
[root@client ~]# rsync -avz root@10.0.0.16:/root/file1 /root/
root@10.0.0.16's password:
receiving incremental file list
file1
sent 43 bytes received 84 bytes 84.67 bytes/sec
total size is 0 speedup is 0.00
[root@client ~]# ls
anaconda-ks.cfg file1 hzz
//传输时限制传输速度
[root@client ~]# dd if=/dev/zero of=/root/1G.txt bs=1024M count=1
记录了1+0 的读入
记录了1+0 的写出
1073741824字节(1.1 GB)已复制,11.0137 秒,97.5 MB/秒
[root@client ~]# rsync -avzP --bwlimit=10 1G.txt root@10.0.0.16:/root/
root@10.0.0.16's password:
sending incremental file list
1G.txt
1,073,741,824 100% 10.66MB/s 0:01:36 (xfr#1, to-chk=0/1)
sent 1,044,300 bytes received 35 bytes 9,993.64 bytes/sec
total size is 1,073,741,824 speedup is 1,028.16
[root@server ~]# ll -h
总用量 1.1G
-rw-r--r-- 1 root root 1.0G 11月 24 10:30 1G.txt
-rw-------. 1 root root 1.3K 11月 23 04:13 anaconda-ks.cfg
-rw-r--r-- 1 root root 0 11月 24 10:24 file1
注意事项:
#备份数据时,若不限速会导致带宽被占满
rsync -avzP --bwlimit=10 1G.txt root@10.0.0.16:/root/
#备份目录时,目录名称后不加"/"表示备份整个目录包含目录本身
rsync -avz dir root@10.0.0.16:/root/
#备份目录时,目录名称后加"/"表示只备份目录中的文件,不备份目录本身
rsync -avz dir/ root@10.0.0.16:/root/
#使用"--delete"选项时,请注意千万不要写错目标目录的名称
#下面命令会导致目标系统"/"目录被清空
rsync -avz --delete dir root@10.0.0.16:/ root/
4、Rsync服务模式
远程模式在传输数据时使用ssh远程登录,使用的是系统用户(不安全);服务模式以守护进程的方式运行,使用的是虚拟用户,用户不存在操作系统中。
4.1 服务端配置
- 确保rsync服务已经安装
- 修改服务配置文件/etc/rsyncd.conf
- 创建用户以及数据存放目录
- 创建虚拟用户密码文件并设置权限
- 关闭防火墙、selinux
- 重启服务并将服务设置开机自启
- 检查服务端口是否开启
#安装rsync服务
[root@server ~]# yum -y install rsync
#编辑服务配置文件/etc/rsyncd.conf
[root@server ~]# vim /etc/rsyncd.conf
uid = rsync #运行服务的用户
gid = rsync #运行服务的组
address = 10.0.0.16 #服务监听地址
port = 873 #服务监听端口
fake super = yes #服务无需使用root用户身份,即可接收文件的完整属性
use chroot = yes #禁锢数据目录,不允许跳出
max connections = 4 #最大连接数
timeout = 900 #超时时间
ignore errors #忽略某些错误信息
read only = false #客户是否只读
list = false #不允许查看模块信息
auth users = rsync_hzz #定义虚拟用户,用户数据传输
secrets file = /etc/rsync.passwd #定义虚拟用户密码认证文件
[backup] #定义模块名称
path = /backup #数据存放目录
comment = backup #模块注释信息
#创建用户以及数据存放目录
[root@server ~]# useradd -r rsync
[root@server ~]# mkdir /backup
[root@server ~]# chown -R rsync.rsync /backup
#创建虚拟用户密码文件并设置权限
[root@server ~]# vim /etc/rsync.passwd
rsync_hzz:passwd
[root@server ~]# chmod 600 /etc/rsync.passwd
#关闭防火墙、selinux
[root@server ~]# systemctl status firewalld.service
● firewalld.service - firewalld - dynamic firewall daemon
Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
Active: inactive (dead)
Docs: man:firewalld(1)
[root@server ~]# getenforce
Disabled
#重启服务并设置服务开机自启
[root@server ~]# systemctl restart rsyncd
[root@server ~]# systemctl enable rsyncd
Created symlink from /etc/systemd/system/multi-user.target.wants/rsyncd.service to /usr/lib/systemd/system/rsyncd.service.
#检查服务端口是否开启
[root@server ~]# ss -anltup | grep "rsync"
tcp LISTEN 0 5 10.0.0.16:873 *:* users:(("rsync",pid=31344,fd=4))
4.2 客户端配置
- 客户端也须安装rsync
- 配置密码文件并设置权限
- 测试收发数据
#客户端安装rsync
[root@client ~]# yum -y install rsync
#配置传输密码
#方法1:将密码写入文件
[root@client ~]# echo 'passwd' > /etc/rsync.pass
[root@client ~]# cat /etc/rsync.pass
passwd
[root@client ~]# chmod 600 /etc/rsync.pass
#测试收发数据
[root@client ~]# rsync -avz --password-file=/etc/rsync.pass /root/file1 rsync_hzz@10.0.0.16::backup
sending incremental file list
file1
sent 88 bytes received 43 bytes 262.00 bytes/sec
total size is 0 speedup is 0.00
[root@server ~]# ls /backup/
file1
#方法2:使用密码环境变量RSYNC_PASSWORD
[root@client ~]# export RSYNC_PASSWORD='passwd'
#测试收发数据
[root@client ~]# touch file2
[root@client ~]# rsync -avz /root/file2 rsync_hzz@10.0.0.16::backup
sending incremental file list
file2
sent 87 bytes received 43 bytes 260.00 bytes/sec
total size is 0 speedup is 0.00
[root@server ~]# ls /backup/
file1 file2
5、Rsync服务模式实战
- 客户端每天凌晨3点备份/etc目录至/backup下以"主机名_IP地址_当前时间命名"的目录中
- 客户端推送/backup目录下数据备份目录至Rsync备份服务器
- 客户端只保留最近七天的备份数据,避免浪费磁盘空间
- 服务端部署rsync服务,用于接收用户的备份数据
- 服务端每天校验客户端推送过来的数据是否完整,并将结果以邮件的方式发送给管理员
- 服务端仅保留6个月的备份数据
注意:所有服务器的备份目录均为/backup,所有脚本存放目录均为/scripts。
服务端部署rsync服务:
[root@server ~]# mkdir /scripts
[root@server ~]# vim /scripts/rsync_server.sh
#!/bin/bash
#安装rsync服务
yum -y install rsync
#配置rsync服务
cat > /etc/rsyncd.conf << EOF
uid = rsync
gid = rsync
port = 873
fake super = yes
use chroot = yes
max connections = 4
timeout = 900
ignore errors
read only = false
list = false
auth users = rsync_backup
secrets file = /etc/rsync.passwd
[backup]
path = /backup
comment = backup
EOF
#创建服务用户,创建数据备份目录并设置权限
useradd -r rsync
mkdir /backup
chown -R rsync.rsync /backup
#生成数据传输用户密码文件并设置权限
echo "rsync_backup:passwd" > /etc/rsync.passwd
chmod 600 /etc/rsync.passwd
#关闭防火墙和selinux
systemctl stop firewalld
setenforce 0
#设置服务开机自启,并重启服务
systemctl enable rsyncd
systemctl restart rsyncd
[root@server ~]# chmod +x /scripts/rsync_server.sh
[root@server ~]# /scripts/rsync_server.sh
客户端备份数据并推送至rsync服务器:
[root@client ~]# mkdir /scripts
[root@client ~]# vim /scripts/etc_backup.sh
#!/bin/bash
#客户端安装rsync
yum -y install rsync
#配置rsync客户端虚拟用户密码
export RSYNC_PASSWORD='passwd'
#创建备份目录
mkdir -p /backup/$(hostname)_$(ip addr show ens36 | awk -F '[ /]+' 'NR==3 {print $3}')_$(date "+%F")
#打包备份/etc目录下的数据至备份目录中
tar -zcf /backup/$(hostname)_$(ip addr show ens36 | awk -F '[ /]+' 'NR==3 {print $3}')_$(date "+%F")/etc_backup.tar.gz /etc/
#计算备份文件的校验值
md5sum /backup/$(hostname)_$(ip addr show ens36 | awk -F '[ /]+' 'NR==3 {print $3}')_$(date "+%F")/etc_backup.tar.gz > /backup/$(hostname)_$(ip addr show ens36 | awk -F '[ /]+' 'NR==3 {print $3}')_$(date "+%F")/checksum.txt
#将打包备份好的数据推送到rsync备份服务器
rsync -az /backup/$(hostname)_$(ip addr show ens36 | awk -F '[ /]+' 'NR==3 {print $3}')_$(date "+%F") rsync_backup@10.0.0.16::backup
#删除七天前的备份文件
find /backup/ -mtime +7 | xargs rm -rf
[root@client ~]# chmod +x /scripts/etc_backup.sh
[root@client ~]# crontab -e
0 3 * * * /scripts/etc_backup.sh
服务端校验数据并将结果以邮件发送给管理员:
#配置邮件服务
[root@server ~]# yum -y install mailx
[root@server ~]# cat > /etc/mail.rc << EOF
set from=2207118234@qq.com
set smtp=smtps://smtp.qq.com:465
set smtp-auth-user=2207118234@qq.com
set smtp-auth-password=xxxxxxxxx
set smtp-auth=login
set ssl-verify=ignore
set nss-config-dir=/etc/pki/nssdb/
EOF
#配置脚本校验数据并将结果发送给管理员
[root@server ~]# vim /scripts/checksum.sh
#!/bin/bash
#校验备份数据并将结果发送给管理员
md5sum -c /backup/client_10.0.0.15_$(date "+%F")/checksum.txt | mail -s "/backup/client_10.0.0.15_$(date "+%F")" 2207118234@qq.com
#删除6个月以前的备份数据
find /backup/ -mtime +180 | xargs rm -rf
[root@server ~]# chmod +x /scripts/checksum.sh
[root@server ~]# crontab -e
0 6 * * * /scripts/checksum.sh