已知3台服务器主机名分别为web01、backup 、nfs主机信息见下表:

角色		     外网IP(NAT)			  内网IP(LAN)			主机名
WEB eth0:10.0.0.7 eth1:172.16.1.7 web01
NFS eth0:10.0.0.31 eth1:172.16.1.31 nfs
Rsync eth0:10.0.0.41 eth1:172.16.1.41 backup 客户端: web nfs
服务端: backup

Client客户端需求:

1.客户端提前准备存放的备份的目录,目录规则如下:/backup/nfs_172.16.1.31_2019-09-06

2.客户端在本地打包备份(系统配置文件、应用配置等)拷贝至/backup/nfs_172.16.1.31_2019-09-06

3.客户端最后将备份的数据进行推送至备份服务器

4.客户端服务器本地保留最近7天的数据, 避免浪费磁盘空间

5.客户端每天凌晨1点定时执行该脚本

Server服务端需求:

1.服务端部署rsync,用于接收客户端推送过来的备份数据

2.服务端需要每天校验客户端推送过来的数据是否完整

3.服务端需要每天校验的结果通知给管理员

4.服务端仅保留6个月的备份数据,其余的全部删除

5.服务端每天定时校验结果

服务端(Server)部署Rsync

#1.安装
[root@backup ~]# yum install rsync -y
#2.配置
[root@backup ~]# vim /etc/rsyncd.conf
uid = rsync
gid = rsync
port = 873
fake super = yes
use chroot = no
max connections = 200
timeout = 600
ignore errors
read only = false
list = false
auth users = rsync_backup
secrets file = /etc/rsync.passwd
log file = /var/log/rsyncd.log
#####################################
[backup]
comment = welcome to oldboyedu backup
path = /backup #3.根据配置创建一些环境
3.1创建rsync用户
[root@backup ~]# groupadd rsync
[root@backup ~]# useradd rsync -M -s /sbin/nologin -g rsync
[root@backup ~]# id rsync
uid=1000(rsync) gid=1000(rsync) groups=1000(rsync) 3.2创建虚拟用户和密码
[root@backup ~]# echo "rsync_backup:123456" > /etc/rsync.passwd
[root@backup ~]# chmod 600 /etc/rsync.passwd 3.3创建backup目录
[root@backup ~]# mkdir /backup
[root@backup ~]# chown -R rsync.rsync /backup/ #4.启动服务
[root@backup ~]# systemctl start rsyncd
[root@backup ~]# systemctl enable rsyncd #5.检查
[root@backup ~]# netstat -lntup |grep rsync
tcp 0 0 0.0.0.0:873 0.0.0.0:* LISTEN 1594/rsync
tcp6 0 0 :::873 :::* LISTEN 1594/rsync

Client端操作:

思路:

1.你需要备份什么?

/etc/fstab /etc/hosts /etc/passwd /var/spool/cron/

2.你要备份到哪里?

/backup/nfs_172.16.1.31_2018-09-02

IP: ifconfig eth1 | awk 'NR==2 {print $2}'

host: hostname

date: date +%F

3.你要推送到哪里?

172.16.1.41


注意:所有服务器的备份目录必须都为/backup

快递:  散货-------->打包--->标记------->装车-------------->运输------------->仓库
验货-------->评价 系统: 备份的文件-->打包--->校验值----->备份至本地目录---->网络-------->推送至备份服务器
管理员校验-->通知--->邮件
#创建存放脚本的位置:
[root@nfs ~]# mkdir -p /server/scripts/
#根据要求遍写脚本:
[root@nfs ~]# vim /server/scripts/push_data_server.sh
#!/usr/bin/bash
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin Path=/backup
Host=$(hostname)
Addr=$(ifconfig eth1 |awk 'NR==2 {print $2}')
Date=$(date +%F) Dest=${Host}_${Addr}_${Date} #1.创建存放备份的目录
[ -d $Path/$Dest ] || mkdir -p $Path/$Dest #2.打包本地文件至备份目录
cd / && \
[ -f $Path/$Dest/sys.tar.gz ] || tar czf $Path/$Dest/sys.tar.gz etc/fstab etc/hosts etc/passwd && \
[ -f $Path/$Dest/other.tar.gz ] || tar czf $Path/$Dest/other.tar.gz var/spool/cron/ && \ #3.增加标记
md5sum $Path/$Dest/*.tar.gz > $Path/$Dest/flag_${Date} #4.将备份的数据推送至远程服务器
export RSYNC_PASSWORD=123456
rsync -avz $Path/ rsync_backup@172.16.1.41::backup #5.客户端服务器本地保留最近7天的数据
find $Path/ -type d -mtime +7 | xargs rm -rf
------------------------------------------------------------------------------------------------------
##批量的模拟数据
[root@nfs ~]# for i in {1..30};do date -s "201909$i"; sh /scripts/clinet_push_data_server.sh ;

Server端操作:

------------------服务端配置邮件功能--------------------

1.安装
[root@backup ~]# yum install mailx -y 2.配置
[root@backup ~]# vim /etc/mail.rc //最后一行下边添加如下内容:
set from=xxxx@qq.com //发件人QQ
set smtp=smtps://smtp.qq.com:465
set smtp-auth-user=xxxx@qq.com //发件人QQ
set smtp-auth-password=xxxxxxxxxxx //QQ授权码
set smtp-auth=login
set ssl-verify=ignore
set nss-config-dir=/etc/pki/nssdb/ 3.测试一下是否能发送成功
[root@backup ~]# mail -s "Rsync Backup" 991540698@qq.com < /etc/hosts 4.编写脚本
[root@backup ~]# mkdir -p /server/scripts
[root@backup ~]# vim /server/scripts/check_data_notify.sh
#!/usr/bin/bash
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin Path=/backup
Date=$(date +%F) #1.校验客户端推送过来的数据
md5sum -c ${Path}/*_${Date}/flag_${Date} > ${Path}/result_${Date} #2.将校验的结果通知给管理员
mail -s "Rsync Backup ${Date}" 991540698@qq.com < ${Path}/result_${Date} #3.服务端保留最近180天的备份数据
find $Path/ -type d -mtime +180 | xargs rm -rf #定时任务:
客户端
[root@nfs ~]# crontab -l
#客户端每天凌晨1点定时执行该脚本
*/2 * * * * sh /server/scripts/push_data_server.sh &> /dev/null 服务端
[root@backup ~]# crontab -l
#定时校验备份的结果
*/2 * * * * sh /server/scripts/check_data_notify.sh &> /dev/null 如何增加多台客户端服务器备份数据?
[root@web01 ~]# rsync -avz root@172.16.1.31:/server /
[root@web02 ~]# rsync -avz root@172.16.1.31:/server /
[root@web03 ~]# rsync -avz root@172.16.1.31:/server /
[root@web04 ~]# rsync -avz root@172.16.1.31:/server /
[root@web05 ~]# rsync -avz root@172.16.1.31:/server /

......................................................

3. Rsync-远程同步(下)-企业案例的更多相关文章

  1. rsync远程同步的基本配置与使用

    rsync是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树,支持增量备份,保持链接和权限,且采用优化的同步算法,传输前执行压缩,因此非常适用于异地备份,镜像服务器等应用. rsync的官 ...

  2. hadoop(六)rsync远程同步|xsync集群分发(完全分布式准备三)|8

    前置环境准备:centos7克隆ip|机器名|映射关系|别名配置(hadoop完全分布式准备一)scp命令copy文件和配置(hadoop完全分布式准备二) rsync远程同步工具 优点 rsync主 ...

  3. rsync 远程同步 实时同步备份 两种免交互的方式实现实时备份

    rsync 远程同步: 一款快速增量备份工具 Remote Sync,远程同步 支持本地复制,或者与其他SSH.rsync主机同步 作用:做数据备份 备份方式:      完全备份      增量备份 ...

  4. Rsync远程同步工具使用

    rsync远程同步工具使用 Rsync(remote synchronize) 是一个远程数据同步工具,可以使用"Rsync算法"同步本地和远程主机之间的文件.Rsync的好处是只 ...

  5. rsync 远程同步部署——上下行同步

    rsync 远程同步部署--上下行同步 1.rsync (Remote Sync,远程同步) : 是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树,支持增量备份,并保持链接和权限,且采用 ...

  6. linux下ssh远程登录/scp远程复制文件/rsync远程同步命令的自动登录

    最近需要写一个脚本备份各个服务器上的程序到一个指定服务器上,本来以为查查rsync命令的使用321就能搞定,结果rsync命令要支持自动登 录还是要配置服务和参数,又不确定网上说的配置的行不行,因为都 ...

  7. rsync远程同步

    一.概念 Rsync是一个开源的快速备份工具,可以在不同主机之间镜像同步整个目录树,支持增量备份,保持连接和权限,且采用优化的同步算法,传输前执行压缩,因此非常适用于异地备份,镜像服务器等应用.rsy ...

  8. rsync - 远程同步工具

    一直没有对这个命令太有深入的理解 简介 rsync 即 remote sync,一个远程与本地文件同步工具.rsync 使用的算法能够最小化所需复制的数据,因为它只移动那些修改了的文件. rsync ...

  9. CentOS6.5使用rsync远程同步

    需达成目标:在服务器(192.168.18.211)端搭建 rsync 服务,       将 /root/rsync-server/ 目录同步到客户端 /root/rsync-local 目录 Li ...

随机推荐

  1. 洛谷 P3868 [TJOI2009]猜数字

    题意简述 给定\(a[1],a[2],\cdots,a[n]\) 和 \(b[1],b[2],\cdots,b[n]\),其中\(b\)中元素两两互素. 求最小的非负整数\(n\),满足对于任意的\( ...

  2. 引用、浅拷贝及深拷贝 到 Map、Set(含对象assign、freeze方法、WeakMap、WeakSet及数组map、reduce等等方法)

    从引用聊到深浅拷贝,从深拷贝过渡到ES6新数据结构Map及Set,再到另一个map即Array.map()和与其类似的Array.flatMap(),中间会有其他相关话题,例如Object.freez ...

  3. js控制滚动条在内容更新超出时自动滚到底部

    //滚动条在内容更新时自动滚到底部var message = document.getElementById('message');message.scrollTop = message.scroll ...

  4. 【数据结构与算法】--JavaScript 链表

    一.介绍 JavaScript 原生提供了数组类型,但是却没有链表,虽然平常的业务开发中,数组是可以满足基本需求,但是链表在大数据集操作等特定的场景下明显具有优势,那为何 JavaScript 不提供 ...

  5. CSS定位与布局

    我们在编写网页代码时,首先应该做的就是设计好页面的布局形式,然后再往里面填充内容.网页布局的好与坏,直接决定了网页最终的展示效果.PC端常见的网页布局形式有两列布局.三列布局等.在CSS中,我们通常使 ...

  6. Fast Earth - 文本 绘制,如何实现三维空间中绘制屏幕大小的文字?

    如题:先上一张图,在说是如何实现的 实现上图效果,有如下三种方式: 1. 屏幕坐标绘制点要素,即将经纬度坐标转换成屏幕坐标方式绘制,大多数GIS系统都是采用这种方式: 优点:实现方式简单,效果较好 缺 ...

  7. [Android Studio] 2019年Android Studio配置指北

    Android Studio是我学习Android开发路上的第一块绊脚石,新建一个项目,一行代码没动,直接编译不起来,我太难了,所以本文叫指北 本文讲解在9102年如何在国内网络不通畅的情况下流畅的使 ...

  8. 快学Scala 第十一课 (类继承)

    类继承: class People { } class Emp extends People{ } 和Java一样,final的类不能被继承.final的字段和方法不能被override. 在Scal ...

  9. k8s pod访问不通外网问题排查

    环境概况 自建k8s集群,主机操作系统ubuntu16.04,k8s版本v1.14, 集群网络方案calico-3.3.6. worker节点数50+,均为GPU物理服务器,服务器类型异构,如Nvid ...

  10. Spring Security 自定义登录认证(二)

    一.前言 本篇文章将讲述Spring Security自定义登录认证校验用户名.密码,自定义密码加密方式,以及在前后端分离的情况下认证失败或成功处理返回json格式数据 温馨小提示:Spring Se ...