Loading

5、rsync全网备份


定时备份rsync(增量备份,无差异备份,daemon进程)+crontab,主要备份一些任务脚本和配置文件,如果此时有用户增加数据,

如果是增量备份的话不会备份下来,因为在备份的那一刻,数据已经被锁定了,所以定时的备份最好备份点为用户不操作数据时进行;

tar命令 和rsync命令使用时如果相同的文件更新时,会自动覆盖,mkdir -p:有目录就用现有的目录,无目录会创建,

touch当有相同的文件时只改变时间戳,而不改变内容,不报错有助于随时随地的备份,sync对比后没有更新的文件不会传送,

对比很浪费时间,因此需要优化这个;

5.1、在rsync备份服务器上,配置rsync服务:

服务端成功配置rsync,并在客户端成功推送

5.2、在客户端nfs服务器上,实现打包,推送,删除,定时任务推送:

打包:tar zcvfh /backup/backup_$(date +%F).tar.gz var/spool/cron/root etc/rc.local etc/sysconfig/iptables var/www/html app/logs

#h表示打包这个软链接对应的原文件

推送:rsync -avz /backup/ rsync_backup@172.16.1.41::backup/ --password-file=/etc/rsync.password

删除: find /backup/ -type f -name "*.tar.gz" -mtime +7| xargs rm -vf

(1)写入脚本文件:

[root@nfs01 /]# mkdir -p /server/scripts

[root@nfs01 /]# cd /server/scripts

[root@nfs01 scripts]# vim bak.sh

#!/bin/sh

export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

Ip=$(ifconfig eth1 | awk -F "[ :]+" 'NR==2 {print $4}')

Path=/backup

if [ $(date +%w) -eq 0 ]

then

Time=week_$(date +%F_%w -d -1day)

else

Time=$(date +%F -d -1day)

fi

cd /

mkdir $Path/$Ip/ -p

tar zcfh $Path/$Ip/backup_${Time}.tar.gz var/spool/cron/root etc/rc.local etc/sysconfig/iptables var/www/html app/logs

md5sum $Path/$Ip/backup_${Time}.tar.gz >$Path/$Ip/flag_${Time}.log

rsync -az $Path/ rsync_backup@172.16.1.41::backup/ --password-file=/etc/rsync.password

find $Path/ -type f -mtime +7 \( -name "*.tar.gz" -o -name "*.log" \) |xargs rm -f

chmod u+x /server/scripts/bak.sh

(2)定时任务:

crontab -e

00 00 * * * /bin/sh /server/scripts/bak.sh >/dev/null 2>&1

#每天的零点启动脚本如果更改日期比如2018/10/20 此时会导致脚本直接运行

[root@m01 ~]# date +%Y_%m_%d\ %H:%M:%S

2018_10_20 14:33:52

5.3、在rsync备份服务器上做检查,发邮件给管理员 (只对当天备份的内容进行校验和发送,删除除180天以前除周六的备份文件和数据)

(1)写入脚本:

[root@nfs01 /]# mkdir -p /server/scripts

[root@nfs01 /]# cd /server/scripts

[root@nfs01 scripts]# vim check_del_data.sh

#!/bin/sh

export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

LANG=en

Path=/backup

if [ $(date +%w) -eq 0 ]

then

Time=week_$(date +%F_%w -d -1day)

else

Time=$(date +%F -d -1day)

fi

find $Path/ -type f -name "flag_${Time}.log" |xargs md5sum -c >>$Path/flag_${Time}_md5sum_result.log 2>&1

mail -s "$Time bak result" hyjy2504164765@163.com <$Path/flag_${Time}_md5sum_result.log

find $Path/ -type f -mtime +180 ! -name "*week*6*" |xargs rm -f

chmod u+x /server/scripts/bak.sh

(2)定时任务:

crontab -e

00 06 * * * /bin/sh /server/scripts/check_del_data.sh >/dev/null 2>&1 #在数据传输完成时再校验和删除

(3)发送邮件:

A、163邮箱设置:

B、

vim /etc/mail.rc

set from=hyjy2504164765@163.com smtp=smtp.163.com smtp-auth-user=hyjy2504164765 smtp-auth-password=linux123 smtp-auth=login #163邮箱

5.4、邮箱服务介绍:

#安装mailx邮件服务

yum install mailx -y

#配置文件追加信息(/etc/mail.rc)

vim /etc/mail.rc

#发件人信息

set from=hyjy2504164765@163.com smtp=smtp.163.com smtp-auth-user=hyjy2504164765 smtp-auth-password=linux123 smtp-auth=login

from=hyjy2504164765@163.com #发件人邮箱地址(163设置得开起允许代理)

smtp=smtp.163.com #smtp地址

smtp-auth-user=hyjy2504164765 #邮箱用户名,不用加域名

smtp-auth-password=linux123 #邮箱密码(邮件密码是smtp代理授权码)

smtp-auth=login #邮箱验证方式

#测试发送

echo "邮件内容" | mail -s "标题" 邮箱地址

echo "hello world" | mail -s "hello" hyjy2504164765@163.com

#最好把你的发送邮件地址加入你接收邮箱的白名单,不然发多了可能被认为发送垃圾邮件而被163拒绝,这是真的



posted @ 2020-02-15 21:39  云起时。  阅读(176)  评论(0编辑  收藏  举报