第一步:准备环境
这里以三台服务器为例实现全网备份项目。
备份服务器 nfs储存服务器 web服务器
主机名 backup nfs01 web01
内网IP地址 172.16.1.41 172.16.1.31 172.16.1.7
外网ip地址 192.168.127.41 192.168.127.31 192.168.127.7
第二步:全网备份需要实现的需求总结
1、所有服务器的打包压缩存储备份数据的目录均为/backup
mkdir -p /backup
2、要备份的文件有
a 定时任务的配置文件(/var/spool/cron/root)【web服务器和nfs服务器】
b 开启自启动的配置文件(/etc/rc.local)【web服务器和nfs服务器】
c 日常脚本的目录(/server/scripts)
d 防火墙iptables的配置文件(/etc/sysconfig/iptables)
e 自己还想备份的文件加入()
tar -zchf /backup/system_backup_$(date +%F_week%w).tar.gz ./var/spool/cron/root ./etc/rc.local ./server/scripts ./etc/sysconfig/iptables
3、web服务器站点目录假定为(/var/html/www)
tar -zchf /backup/system_backup_$(date +%F_week%w).tar.gz ./var/html/www/
4、web服务器01访问日志路径假定为(/app/logs)
tar -zchf /backup/system_backup_$(date +%F_week%W).tar.gz ./app/logs/
-h,--dereference follow symlinks; archive and dump the files theypoint to
将链接文件所指向的原文件进行保存备份
%w, 将日期以周几的方式记录
5、web服务器保留打包后的7天的备份数据即可(本地保存不能多于7天,清除磁盘存储)
find /backup/ -type f -mtime +7 | xargs rm 2>/dev/null
6、备份服务器上,保留每周一的所有数据副本,其他要保留6个月的数据副本
find /backup/ -type f -mtime +180 ! -name "*week1.tar.gz" | xargs rm 2>/dev/null
7、备份服务器上要按照备份数据服务器的内网ip为目录保存备份,备份的文件按时间名字保存
mkdir -p /backup/`hostname -i`
8、*需要确认备份的数据尽量完整正确,在备份服务器上对备份的数据进行检查,把备份成功或者失败的信息发给系统管理者
客户端:find /backup/ -type f -mtime -1 ! -name "finger*" | xargs md5sum > /backup/finger.txt
服务端:find /backup/ -type f -name "finger.txt" | xargs md5sum -c >/tmp/check.txt
mail -s "$(date +%F)备份结果." [email protected] < /tmp/check.txt
==服务端需要配置好邮件发送的功能==
ps:注意以上要求备份的目录没有的话手动创建模拟生产环境
第三步、配置好邮件发送功能
设置代理发送邮件的邮箱:
a 配置163企业邮箱
设置—>POP3/SMTP/IMAP—>勾选IMAP/SMTP服务,不勾选POP/SMTP服务—>保存
记住客户端授权密码
b 编写linux服务邮箱相关配置文件
vim /etc/mail.rc
set [email protected] smtp=smtp.163.com
set [email protected] smtp-auth-password=yxb19991216 smtp-auth=login
第四步:编写全网备份脚本
客户端
#!/usr/bin/env bash
Backup_dir="/backup"
#Ip_info=$(hostname -i)
Ip_info=`hostname -i`
#create backup dir
mkdir -p $Backup_dir/$Ip_info
# tar backup data
cd /
tar -zchf $Backup_dir/$Ip_info/system_backup_$(date +%F_week%w).tar.gz ./var/spool/cron/root ./etc/rc.local ./server/scripts ./etc/sysconfig/iptables
# del 7 day ago info
find $Backup_dir -type f -mtime +7 | xargs rm 2>/dev/null
# create finger file
find $Backup_dir/ -type f -mtime -1 ! -name "finger*"|xargs md5sum > $Backup_dir/$Ip_info/finger.txt
# backup push data info
rsync -az $Backup_dir/ [email protected]::backup --password-file=/etc/rsync.password
定时执行脚本:
crontab -e
0 0 * * * /usr/bin/bash /server/scripts/backup.sh
服务端
#!/usr/bin/env bash
# del 180 day ago data
find /backup/ -type f -mtime +180 ! -name "*week1.tar.gz" | xargs rm 2>/dev/null
# check backup data
find /backup/ -type f -name "finger.txt" | xargs md5sum -c >/tmp/check.txt
# send check mail
#mail -s "check backup info for $(date +%F)" [email protected] </tmp/check.txt
mail -s "$(date +%F)备份信息。" [email protected] < /tmp/check.txt
crontab -e
0 0 * * * /usr/bin/bash /server/scripts/server_backup.sh
提示:没有邮件功能的话可以下载安装
yum -y install mailx-12.5-19.el7.x86_64
前提:需要部署好rsync守护进程方式备份,配置好配置文件。
yum -y install rsync-3.1.2-6.el7_6.1.x86_64