34. Rsync 全网备份

客户端需求
  1.客户端提前准备存放的备份的目录,目录规则如下:/backup/nfs_172.16.1.31_2018-09-02
  2.客户端在本地打包备份(系统配置文件、应用配置等)拷贝至/backup/nfs_172.16.1.31_2018-09-02
  3.客户端最后将备份的数据进行推送至备份服务器
  4.客户端服务器本地保留最近7天的数据, 避免浪费磁盘空间
  5.客户端每天凌晨1点定时执行该脚本

服务端需求
  1.服务端部署rsync,用于接收客户端推送过来的备份数据
  2.服务端需要每天校验客户端推送过来的数据是否完整
  3.服务端需要每天校验的结果通知给管理员
  4.服务端仅保留6个月的备份数据,其余的全部删除

注意:所有服务器的备份目录必须都为/backup   建议备份的数据内容如下   /etc/rc.local
/etc/fstab /etc/hosts   /var/spool/cron/
/etc/firewalld /server/scripts


准备3台服务器主机名分别为web01、backup 、nfs主机信息见下表:

角色外网IP(NAT)   内网IP(LAN)主机名
WEBeth0:10.0.0.7 eth1:172.16.1.7web01
NFSeth0:10.0.0.31 eth1:172.16.1.31nfs01
Rsynceth0:10.0.0.41 eth1:172.16.1.41backup

一,客户端

遇到的问题:
1.我要备份什么? /etc/rc.local /etc/fstab /etc/hosts /var/spool/cron/ /etc/firewalld /server/scripts
2.我要备份到哪里? /backup目录 该主机的主机名称_该主机的IP地址_今天的日期
3.我要推送到哪儿? 备份服务器 172.16.1.41 backup模块


执行成功再粘贴进脚本中
1.我们要准备一个目录
[root@nfs ~]# mkdir -p "/backup/$(hostname)_$(ifconfig eth1 | awk '/inet / {print $2}')_$(date +%F)"

2.将文件备份到该目录中
[root@nfs ~]# cp -r /etc/rc.local /etc/fstab /etc/hosts /backup/nfs_172.16.1.31_2020-04-15/

3.使用rsync命令进行运输
[root@nfs ~]# rsync -avz /backup/ rsync_backup@172.16.1.41::backup

4.保留最近7天
[root@nfs ~]# for i in {1..30};do date -s 2020/04/$i && sh /scripts/clinet_push_data.sh ;done #测试拿来用就OK
[root@nfs ~]# find /backup -type d -mtime +7 | xargs rm -rf

5.编写定时任务
[root@nfs backup]# crontab -l
#backup \* * * * * /usr/bin/sh /scripts/clinet_push_data.sh &>/dev/null #测试 #00 01 * * * /usr/bin/sh /scripts/clinet_push_data.sh &>/dev/null


6.脚本编写:(将手动执行成功的1 2 3 4 5 写成一个脚本)

[root@nfs ]#   vim /scripts/clinet_push_data.sh    
#!/usr/bin/bash
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin  
#( echo $PATH 粘贴-》申明命令执行的路径)
#固定的字符=不确定的值 ---------->>> 变量的使用让所有的调用可以变得灵活

Host=$(hostname)
Addr=$(ifconfig eth1 | awk '/inet / {print $2}')
Time=$(date +%F)
Path=/backup
DirName="${Host}_${Addr}_${Time}"


#1.我们要准备一个目录
mkdir -p  "$Path/$DirName"

#2.将文件备份到该目录中
cp -r /etc/rc.local /etc/fstab  /etc/hosts    $Path/$DirName

#3.使用rsync命令进行运输(脚本中免密操作)
export RSYNC_PASSWORD=123456
rsync -avz $Path/ rsync_backup@172.16.1.41::backup


#4.保留本地7天的数据
find $Path  -type d -mtime +7  | xargs rm -rf

5.配置定时任务,定时执脚本
测试:
sh /scripts/clinet_push_data.sh


二,服务端

(ntpdate time.windows.com #同步服务器时间)

  1. 服务端部署rsync,用于接收客户端推送过来的备份数据
  2. 服务端需要每天校验客户端推送过来的数据是否完整

md5sum命令用于生成和校验文件的md5值。它会逐位对文件的内容进行校验。是文件的内容,与文件名无关,也就是文件内容相同,其md5值相同。md5值是一个128位的二进制数据,转换成16进制则是32(128/4)位的进制值。

md5校验,有很小的概率不同的文件生成的md5可能相同。比md5更安全的校验算法还有SHA*系列的。
在网络传输时,我们校验源文件获得其md5sum,传输完毕后,校验其目标文件,并对比如果源文件和目标文件md5,一致的话,则表示文件传输无异常。否则说明文件在传输过程中未正确传输。

  1. 服务端仅保留6个月的备份数据,其余的全部删除
    流程图
    在这里插入图片描述

首先改客户端推送数据脚本,加入校验功能:

 [root@nfs ~]# vim /scripts/clinet_push_data.sh
#!/usr/bin/bash
#客户端推送备份的数据至备份服务器   by oldxu
#0.将目录需要用的主机名,IP,时间,定义为变量
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
Host=$(hostname)
Addr=$(ifconfig eth1 | awk '/inet / {print $2}')
Time=$(date +%F)
Path=/backup
DirName="${Host}_${Addr}_${Time}"

#1.我们要准备一个目录
mkdir -p  "$Path/$DirName"

#2.将文件备份到该目录中
cd / && \
tar czf $Path/$DirName/sys.tar.gz etc/rc.local etc/fstab && \
tar czf $Path/$DirName/other.tar.gz etc/hosts && \
md5sum  $Path/$DirName/*.tar.gz > $Path/$DirName/check_flag_$Time

#3.使用rsync命令进行运输
export RSYNC_PASSWORD=123456
rsync -avz $Path/ rsync_backup@172.16.1.41::backup

#4.保留本地7天的数据
find $Path  -type d -mtime +7  | xargs rm -rf

反斜杠一般用作转义字符,或称逃脱字符,Linux如果echo要让转义字符发生作用,就要使用-e选项,且转义字符要使用双引号 echo -e “\n”

反斜杠的另一种作用,就是当反斜杠用于一行的最后一个字符时,Shell把行尾的反斜杠作为续行,这种结构在分几行输入长命令时经常使用。

  1. 服务端校验脚本:
    根据客户端推送的封条 --> 校验数据是否一致,最后通知管理员。
[root@backup ~]# cat /scripts/check_clinet_data.sh
#!/usr/bin/bash
#检查客户端推送的数据   by oldxu
#0.将目录需要用的主机名,IP,时间,定义为变量
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
Time=$(date +%F)
Path=/backup

#1.找到当天的check_flag文件,校验数据是否是完整的,并且将校验结果存储至某个文件中
find $Path/ -type f -name "check_flag_$Time" | xargs md5sum -c > $Path/result_$Time

#3.将校验的结果通知给管理人员
mail -s "Rsync Backup $Time" #收件人邮箱 <$Path/result_$Time

#4.服务端仅保留6个月的备份数据,其余的全部删除
find $Path  -type d -mtime +180  | xargs rm -rf

配置发件人邮箱账号密码:

[root@backup ~]# cat /etc/mail.rc

set from=simba777qq.com
set smtp=smtps://smtp.qq.com:465
set smtp-auth-user=simba777@qq.com
set smtp-auth-password=#复制客户端授权码
set smtp-auth=login
set ssl-verify=ignore
set nss-config-dir=/etc/pki/nssdb/

配置定时任务

[root@nfs backup]# crontab -l
#backup
00 01 * * * /usr/bin/sh /scripts/clinet_push_data.sh &>/dev/null

如何快速备份一台新的机器?
[root@web01 ~]# rsync -avz 172.16.1.31:/scripts /
  
接下来完整的测试一把,测试完成后,需要将时间修改为对应的真实时间。

nfs、web: [root@nfs ~]# crontab -l

          • /usr/bin/sh /scripts/clinet_push_data.sh &>/dev/null

backup: [root@backup ~]# crontab -l
*/2 * * * * /usr/bin/sh /scripts/check_clinet_data.sh &>/dev/null


排错:

备份时显示权限不足----->>>查看服务端权限 ,属组属组,rysnc是否启动。
chmod 600 /etc/rsync.passwd
systemctl start rsyncd
  
收不到邮件怎么办?
  1.看看配置文件的邮箱地址
  2.有没有安装mailx
  4.校验失败
    校验脚本写错了
    查看时间是是否相符合
nfs:
ntpdate time.windows.com 同步时间
date -s 2020-xx-xx 修改时间

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值