备份服务实战项目之全网备份项目

第一步:准备环境

这里以三台服务器为例实现全网备份项目。
备份服务器 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

发布了10 篇原创文章 · 获赞 1 · 访问量 198

猜你喜欢

转载自blog.csdn.net/yang_x_b/article/details/104253831