02下 Rsync备份案例
Rsync备份案例:
客户端需求:
1.客户端提前准备存放的备份的目录,目录规则如下:/backup/nfs_172.16.1.31_2018-09-02
2.客户端在本地打包备份(将etc目录中所有的普通文件打包)拷贝至/backup/nfs_172.16.1.31_2018-09-02
3.客户端最后将备份的数据进行推送至备份服务器
4.客户端每天凌晨1点定时执行该脚本
5.客户端服务器本地保留最近7天的数据, 避免浪费磁盘空间
服务端需求:
1.服务端部署rsync,用于接收客户端推送过来的备份数据
2.服务端需要每天校验客户端推送过来的数据是否完整?md5sum
3.服务端需要每天校验的结果通知给管理员
4.服务端仅保留6个月的备份数据,其余的全部删除
1 准备服务器
主机 | ip | 身份 |
---|---|---|
rsync | 192.168.15.41 | 服务端 |
nfs | 192.168.15.31 | 客户端 |
2 客户端
1.客户端提前准备存放的备份的目录,
目录规则如下:/backup/nfs_172.16.1.31_2018-09-02
mkdir /backup
#反引号`date +%F`
mkdir /backup/nfs_172.16.1.31_`date +%F`
2.客户端在本地打包备份(将etc目录中所有的普通文件打包)拷贝至/backup/nfs_172.16.1.31_2018-09-02
tar -czPf /backup/nfs_172.16.1.31_`date +%F`/etc.tar.gz $(find /etc/ -type f)
cd /backup/nfs_172.16.1.31_`date +%F`
md5sum etc.tar.gz > md5sum.txt
3.客户端最后将备份的数据进行推送至备份服务器
rsync -avzP /backup/ rsync_backup@172.16.1.41::backup --password-file=/etc/rsync.passwd
4.客户端服务器本地保留最近7天的数据, 避免浪费磁盘空间
find /backup/ -ctime +7 -name "nfs*" -exec rm -rf {} \;
5 编写脚本
vi /root/rsync.sh
写入下面内容:
mkdir /backup
mkdir /backup/nfs_172.16.1.31_`date +%F`
tar -czPf /backup/nfs_172.16.1.31_`date +%F`/etc.tar.gz $(find /etc/ -type f)
cd /backup/nfs_172.16.1.31_`date +%F`
md5sum etc.tar.gz > md5sum.txt
rsync -avzP /backup/ rsync_backup@172.16.1.41::backup --password-file=/etc/rsync.passwd
find /backup/ -ctime +7 -name "nfs*" -exec rm -rf {} \;
添加权限:
chmod +x rsync.sh
6.客户端每天凌晨1点定时执行该脚本
0 1 * * * /root/rsync.sh
3 服务端
1.服务端部署rsync,用于接收客户端推送过来的备份数据
systemctl start rsyncd
2.服务端需要每天校验客户端推送过来的数据是否完整?md5sum
cd /backup/nfs_172.16.1.31_`date +%F`/
md5sum -c md5sum.txt
3.服务端需要每天校验的结果通知给管理员
if [ $? -eq 0 ];then
echo "验证成功" | mail -s "验结果" 163邮箱
else
echo "验证失败" | mail -s "验证结果" chenyangqit@163.com
fi
使用163邮箱
#1.服务端配置邮件功能
[root@rsync~]# yum install mailx -y
[root@rsync~]# vim /etc/mail.rc
set from=写自己的163邮箱
set smtp=smtps://smtp.163.com:465
set smtp-auth-user=写自己的163邮箱
set smtp-auth-password=JMEHJRULSYTSRLJH #授权密码管理的密码
set smtp-auth=login
set ssl-verify=ignore
set nss-config-dir=/etc/pki/nssdb/
#2.测试发送邮件
[root@rsync ~]# echo "验证成功" | mail -s "验证结果" 163邮箱
看起来已经成功了,但是发送完邮件还有报错:证书不被信任,且命令行就此卡住,需要按键才能出现命令提示符
自行百度解决。。。
4.服务端仅保留6个月的备份数据,其余的全部删除
find /backup/ -ctime +180 -name "nfs*" -exec rm -rf {} \;
5 编写脚本
vi /root/rsync-server.sh
cd /backup/nfs_172.16.1.31_`date +%F`/
md5sum -c md5sum.txt
if [ $? -eq 0 ];then
echo "验证成功" | mail -s "验证结果" 163邮箱
else
echo "验证失败" | mail -s "验证结果" 163邮箱
fi
增加权限
chmod +x /root/rsync-server.sh
6 测试
/root/rsync-server.sh
知识储备:
md5sum重要的选项:
判断