全网备份需求说明
1.所有服务器的备份目录必须都为/backup
2.要备份的系统配置文件包括但不限于
a) 定时任务服务的配置文件 (/var/spool/cron/root) (适合web和nfs服务器)
b) 开机自启动的配置文件 (/etc/rc.local) (适合web和nfs服务器)
c) 日常脚本的目录 (/server/scripts)
d) 防火墙iptables的配置文件 (/etc/sysconfig/iptables)
3.Web服务器站点目录假定为 /var/html/www
4.Web服务器访问日志路径假定为 /app/logs
5.Web服务器保留打包后的7天的备份数据即可
6.备份服务器上, 保留6个月内数据, 以及每周一的所有数据副本
7.备份服务器上, 要按照备份数据服务器的内网IP为目录保存备份, 备份的文件按照时间名字保存
8.需要确保备份的数据尽量完整正确, 在备份服务器上对备份的数据进行检查, 把备份的成功及失败结果信息发给系统管理员邮箱中
前提准备
mkdir -p /server/scripts /var/html/www /app/logs
touch /etc/sysconfig/iptables
vim /etc/rsync.password
密码
chmod 600 /etc/rsync.password
全网备份数据脚本编写
存储服务器
第一步: 编写脚本
#!/bin/bash
host_IP=$(hostname -i)
backup_data="./var/spool/cron/root ./etc/rc.local ./server/scripts ./etc/sysconfig/iptables"
#01. 创建存储数据目录
mkdir -p /backup/$host_IP/
#02. 将数据本地保存压缩备份
cd /
tar zchf /backup/$host_IP/sys_backup_$(date +%F_星期%w -d "-1 day").tar.gz $backup_data
tar zcf /backup/$host_IP/www_data_$(date +%F_星期%w -d "-1 day").tar.gz ./var/html/www
tar zcf /backup/$host_IP/log_data_$(date +%F_星期%w -d "-1 day").tar.gz ./app/logs
#03. 将当天生成备份文件进行指纹验证,生成指纹文件
find /backup -type f -name "*.tar.gz" -mtime -1 | xargs md5sum >/backup/$host_IP/finger.txt
#04. 实现数据远程备份
rsync -az /backup/ rsync_backup@172.16.1.41::backup --password-file=/etc/rsync.password
#05. 保留近7天的历史数据信息
find /backup/ -type f -name "*.tar.gz" -mtime +7 -delete
第二步: 实现定时任务
crontab -e
0 0 * * * /bin/sh /server/scripts/backup_data.sh &>/dev/null
备份服务器
第一步: 编写脚本
#!/bin/bash
#01. 验证数据完整性
file_count=$(find /backup -type f -name "finger.txt" -mtime -1|wc -l)
if [ $file_count -ne 2 ]
then
echo "finger.txt not sent" | mail -s "finger.txt sent error" 930919789@qq.com
find /backup -type f -name "finger.txt"|xargs md5sum -c >/backup/check_log.txt
else
find /backup -type f -name "finger.txt"|xargs md5sum -c >/backup/check_log.txt
fi
#02. 将验证结果进行邮件发送
mail -s "data_check_$(date +%F_%T)" 930919789@qq.com < /backup/check_log.txt
#03. 进行数据清理操作
find /backup/ -type f ! -name "*星期1*" -a -mtime +180 -delete
第二步: 实现定时任务
crontab -e
0 5 * * * /bin/sh /server/scripts/backup_server.sh &>/dev/null