day 33--Linux架构模型

实现一个备份的案例:

1.角色准备

角色 外网ip 内网ip 主机名
WEB eth0=10.0.0.7 eth1=172.16.1.7 web01
NFS eth0=10.0.0.31 eth1=172.16.1.31 nfs
Rsync eth0=10.0.0.41 eth1=172.16.1.41 backup

客户端需求:

    1. 客户端提前准备存放的备份的目录,目录规则如下:/backup/nfs_172.16.1.31_2019_02_01
    2. 客户端在本地打包备份(系统配置文件,应用配置等)拷贝至/backup/nfs_172.16.1.31_2019_02_01
    3. 客户端最后将备份的数据进行推送至备份服务器
    4. 客户端为避免浪费磁盘空间,删除7天以前的数据
    5. 客户每天陵城1点,定时将数据打包备份至服务端

服务端需求:

    1. 服务端部署rsync服务,用于接收客户端推送过来的数据
    2. 服务端需要每天将客户端推送过来的数据进行检验,看发送过来的数据是否完整
    3. 服务端将每天校验的结果以邮件的形式发送给管理员
    4. 服务端只保留6个月的数据,其余的全部删除
  • PS:所有服务器的备份目录必须都为/backup
    快递: 散货----------->装车-->运输-->

    系统: 备份的文件-->打包-->标记--->备份至本地目录--->网络--->推送至备份服务器

    管理员校验-->通知--->邮件

1.你要备份什么?

    /etc/fstab /etc/hosts /etc/passwd /var/spool/cron/

2.你要备份到哪里去?

     /backup/nfs_172.16.1.31_2018-09-02

      3.你要推送到哪里?

         172.16.1.41

客户端

  • 1.按客户端要求完成数据包的推送
    1.创建一个脚本目录
    [root@nfs ~]# mkdir /scripts
    2.在脚本目录下编写一个备份脚本
    [root@nfs ~]# cat /scripts/clinet_push_data_server.sh
    PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
    Src=/backup
    Host=$(hostname)
    Addr=$(ifconfig eth1 | awk 'NR==2 {print $2}')
    Date=$(date +%F)
    Dest=${Host}_${Addr}_${Date}
    #1.创建对应的备份目录
    [ -d ${Src}/${Date} ] || mkdir -p ${Src}/${Date} #判断是否存在这个目录,如果存在则不创建,如果不存在则执行mkdir
    #2.将文件拷贝至备份目录
    cd / && \  #进入根目录
    [ -f  ${Src}/${Dest}/sys.tar.gz ] || tar czf ${Src}/${Dest}/sys.tar.gz etc/fstab etc/hosts etc/passwd && \ #判断是否存在这个压缩包,如果存在则不执行tar,否则执行
    #3.给打好的压缩包添加标记
    [ -f ${Src}/${Dest}/flag_{Date} ] ||  md5sum ${Src}/${Dest}/*.tar.gz > ${Src}/$Dest/flag_${Date} #判断是否校验打好的压缩包,若目录下存在校验产生的文件,则不校验,否则检验压缩包是否完整
    #4.把校验后的文件和准备好的数据推送至服务端
    export RSYNC_PASSWORD=123456
    rsync -avz ${Src}/ [email protected]::backup #将客户端的备份文件推送到远端服务器上的backup模块下
    #5.保留最近7天的数据
    find ${Src}/ -type d -mtime +7 | xargs rm -rf
    1. 利用定时任务来实现每天定时向服务端推送相应的数据包
    [root@nfs ~]# crontab -e
    */1 * * * * sh /scriptsclinet_push_data_server.sh &>/dev/null
    1. 批量模拟数据
    [root@nfs ~]# for i in {1..30};do date -s "201909$i"; sh /scripts/clinet_push_data_server.sh ; done

服务端

    1. 配置邮件功能
    [root@backup /]# yum install mailx -y
    [root@backup /]# vim /etc/mail.rc   ----->>跳转至最后一行,然后进入编辑模式
    set from=发件人@qq.com
    set smtp=smtps://smtp.qq.com:465
    set smtp-auth-user=发件人@qq.com
    set smtp-auth-password=xxxx        #邮箱授权码
    set smtp-auth=login
    set ssl-verify=ignore
    set nss-config-dir=/etc/pki/nssdb/
    1. 测试一下是否能发送成功
    [root@backup ~]mail -s "测试一下" 收件人@qq.com < /etc/hosts
    1. 编写校验脚本,并定时将校验结果以邮件的形式及时反馈给管理员
    PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
    Src=/backup
    Date=$(date +%F)
    #1.检验每天客户端推送过来的数据
    md5sum -c ${Src}/*_${Date}/flag_${Date} >${Src}/result_${Date}
    #2.发送邮件通知管理员校验结果
    mail -s "Rsync Backup {Date}" 收件人@qq.com < {Src}/result_${Date}
    #保留最近6个月的数据
    find ${Src}/ -type d -mtime +180 | xargs rm -rf
    1. 定时发送校验结果给管理员
    [root@backup ~]# crontab -e
    */1 * * * * sh /scripts/check_data_notify.sh &>/dev/null

增加一个客户端进行备份校验

    [root@web01 ~]# rsync -avz [email protected]:/scripts /

你可能感兴趣的:(day 33--Linux架构模型)