公司实现全网备份项目:(rsync+定时任务)
发布时间:2020-12-14 01:08:14 所属栏目:Linux 来源:网络整理
导读:企业案例:rsync实战: web01 10.0.0.7 backup 10.0.0.41 某公司里有一台Web服务器,里面的数据很重要,但是如果硬盘坏了,数据就会丢失,现在领导要求你把数据在其他机器上做一个周期性定时备份。要求如下:每天晚上12点整在Web服务器A(web01 )上打包备份网
企业案例:rsync实战:
web01 10.0.0.7 backup 10.0.0.41 某公司里有一台Web服务器,里面的数据很重要,但是如果硬盘坏了,数据就会丢失,现在领导要求你把数据在其他机器上做一个周期性定时备份。要求如下: 每天晚上12点整在Web服务器A(web01 )上打包备份网站程序目录并通过rsync命令推送到服务器B(backup)上备份保留 (备份思路可以是先在本地按日期打包,然后再利用rsync推到备份服务器上)。 rsync守护进程模式 定时任务 (脚本) 具体要求如下: 1)Web服务器A和备份服务器B的备份目录必须都为/backup。 #扩展备份到/backup下以ip地址命名的目录下 2)Web服务器站点目录假定为(/var/www/html)。 3)Web服务器本地仅保留7天内的备份。 4)备份服务器上每周六的数据都保留,其他备份仅保留180天备份。 5)备份服务器上检查备份结果是否正常(备份内容变?),并将每天的备份结果发给管理员信箱。** web应用服务器上的操作:1、 先在命令行测试脚本里面的命令,若没有问题再拷贝和粘贴到脚本里面[[email?protected] ~]# cat /server/scripts/bak.sh #!/bin/bash IP=$(hostname -I|awk ‘{print $NF}‘) HOSTNAME=$(hostname) #mkdir dir mkdir -p /backup/$IP mkdir -p /var/www/html #tar tar zcf /backup/$IP/conf-$(date +%F-%w).tar.gz /etc/ /var/www/html #make md5 find /backup/ -type f -name "*.tar.gz"|xargs md5sum >/backup/$IP/web01.md5 #push rsync -avz /backup/ [email?protected]::backup --password-file=/etc/rsync.passwd #del 7 day gao files find /backup/ -type f -name "*.tar.gz" -mtime +7|xargs rm -f 2、测试脚本:[[email?protected] ~]# sh /server/scripts/bak.sh tar: Removing leading `/‘ from member names sending incremental file list 172.16.1.7/conf-2019-05-21-2.tar.gz 172.16.1.7/web01.md5 sent 3,498 bytes received 19,269 bytes 45,534.00 bytes/sec total size is 10,213,793 speedup is 448.62 3、写入定时任务: [[email?protected] ~]# crontab -l #backup * * * * * /bin/sh /server/scripts/bak.sh >/dev/null 2>&1 4、测试定时任务 (先按照每分钟测试,若没有问题再更改实际需要备份的时间) backup服务器端:1、命令行测试[[email?protected] ~]# find /backup/ -type f -name "*.tar.gz" ! -name "*-6.tar.gz" -mtime +180 | xargs rm rm: missing operand Try ‘rm --help‘ for more information.---找不到文件,正常,因为没有,命令没有问题 [[email?protected] ~]# tree /backup /backup └── 172.16.1.7 ├── conf-2019-05-21-2.tar.gz └── web01.md5 1 directory,2 files [[email?protected]~]# md5sum -c /backup/*/*.md5 /backup/172.16.1.7/conf-2019-05-21-2.tar.gz: OK 2、 命令行测试没问题,粘贴进脚本文件[[email?protected] ~]# cat /server/scripts/check.sh #!/bin/bash #check md5sum -c /backup/*/*.md5 >/backup/result.txt #find /backup/ -type f -name "*.md5"|xargs md5sum -c #del 180 ago find /backup/ -type f -name "*.tar.gz" ! -name "*-6.tar.gz" -mtime +180 | xargs rm mail -s "server is GOOD " [email?protected] < /backup/result.txt 3、 测试脚本
4、 设置发邮件给运维管理人员1) 启动系统自带的邮件服务[[email?protected] ~]# systemctl restart postfix.service [[email?protected] ~]# [[email?protected] ~]# systemctl is-active postfix.service active [[email?protected] ~]# systemctl is-enabled postfix.service enabled [[email?protected] ~]# systemctl status postfix.service ● postfix.service - Postfix Mail Transport Agent Loaded: loaded (/usr/lib/systemd/system/postfix.service; enabled; vendor preset: disabled) Active: active (running) since Tue 2019-05-21 15:13:43 CST; 2h 36min ago Process: 7905 ExecStart=/usr/sbin/postfix start (code=exited,status=0/SUCCESS) Process: 7903 ExecStartPre=/usr/libexec/postfix/chroot-update (code=exited,status=0/SUCCESS 2)配置163邮箱---设置--启用pop3和smtp,并设置授权码3)vim /etc/mail.rc最后写入一行: set [email?protected] smtp=smtp.163.com smtp-auth-user=xiaxia_5321 smtp-auth-password=shani123 (授权码) smtp-auth=login 重启一下服务 配置完成!!!运维工程师可以通过邮件,微信,电话等等工具获取服务器相关故障报警信息。(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |