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重要的选项:

判断

 

 

 

posted @ 2021-10-23 15:09  甜甜de微笑  阅读(52)  评论(0编辑  收藏  举报