rsync简介

“rsync是linux系统下的数据镜像备份工具。使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH、rsync主机同步”

rsync的功能和特点

1. 可以实现服务器各种资源的备份(可以夸文件系统)

2. linux-rsync,windows-cwrsync

3. 可以做全量备份,也可以做增量备份

4. 在做备份的时候,可以排除一些特定的文件不做备份

5. 可以结合ssh实现加密传输

6. rsync支持工作在后台的模式(守护进程模式)

7. rsync可以结合inotify/sersync实现自动实时备份

8. rsync在传输文件的过程中可做限速

rsync的工作模式

1. 命令行模式(shell模式)

类似于cp、dd命令,实现备份文件的复制(备份)

2. 远程模式(远程shell模式)

利用ssh实现数据的远程传输,类似于 scp

3. 列表模式

类似于执行ls命令,仅仅用于列出文件内容列表(不是做复制操作)

4. 后台模式(守护进程模式)

rsync是工作在后台的

rsync实现自动备份

rsync实时自动备份

结合inotify/sersync

inotify/sersync:监控文件和目录中的文件是否发生更改(找出新文件)

rsync:将找出的文件备份过去

rsync的用法

1.本地使用(cp)

2.远程使用(scp)

3.守护进程(socket)

rsync选项详解

选项
-p:保持文件的权限属性不变
-v:显示执行过程信息
-r:目录做递归
-a:归档(包含r)
-z:压缩
-l:仅仅传输软链接自身
-L:传输软连接所指向的原始文件
-b:在备份文件的时候,如果备份文件已经存在,会将目标位置下旧的文件重命名,然后生成新的备份
--suffix=xxx 指定旧备份文件的后缀名
--backup-dir=xxxx 指定将旧备份文件移动到哪个位置下
-e:结合ssh实现加密传输
-e "ssh -p 22"
组合:-avz

rsync配置文件参数详解

模块:其实就是一个目录,这个模块用于保存客户端所传递过来的文件
参数:
pid file:指定rsync的pid文件的保存位置
uid:指定运行rsync进程的用户id
gid:指定运行rsync进程的用户组id
port:指定rsync所监听的端口(默认端口873)
path:指定模块所对应的目录的位置
use chroot:指定将用户锁定在家目录中
max connections:最大连接数(指定最多同时有多少个客户端在传输文件)
log file:指定日志文件的位置
log format:指定日志格式
lock file:指定rsync进程的锁文件的位置
read only:指定模块是否为只读状态
write only:指定模块是否为只写状态
list:指定用用户是否可以查看模块所对应的路径下的文件列表
exclude:指定排除不做传输的文件
exclude from:通过读取一个文件,来获取不对哪些文件做传输
auth users:指定用于连接这个模块所要使用的匿名用户名
secrets file:指定保存虚拟用户和密码文件
hosts allow:指定可以做文件传输的主机
hosts deny:黑名单
timeout:指定客户端的超时时间

inotify简介

inotify:查找发送了改变的文件或者新文件,可以持续检测一个目录中的文件是否发生更改。

软件inotify-tools有两个组件

inotifywait:检测一个目录下的文件所发生事件

inotifywatch:统计所触发的事件的次数

inotifywait的选项

    -r:递归目录
-q:仅仅打印监控的事件信息
-m:一直处于监控状态[组合使用-mqr]
--excludei:排除文件或目录(不区分大小写)
--exclude:排除文件或目录(区分大小写)
--format:指定输出格式
%w:显示触发监控的事件的所在路径.[%w%f组合使用就能得到文件名]
%f:显示触发监控的事件的文件名
%e:显示所触发的事件
%T:显示事件的触发时间
--timefmat:指定输出的时间的格式
-e:指定要监控的事件

inotify监控的事件

    access              file or directory contents were read
modify file or directory contents were written
attrib file or directory attributes changed
close_write file or directory closed, after being opened in writeable mode
close_nowrite file or directory closed, after being opened in read-only mode
close file or directory closed, regardless of read/write mode
open file or directory opened
moved_to file or directory moved to watched directory
moved_from file or directory moved from watched directory
move file or directory moved to or from watched directory
create file or directory created within watched directory
delete file or directory deleted within watched directory
delete_self file or directory was deleted
unmount file system containing file or directory unmounted

rsync+inotify全网自动化备份实战案例

1.环境准备

centos7.5

rsync服务端IP:172.20.10.7/28

inotify服务端IP:172.20.10.8/28

2.关闭安全服务

[root@ken ~]# systemctl stop firewalld
[root@ken ~]# setenforce
[root@ken ~]# iptables -F

3. 配置rsync服务端

创建共享目录

[root@ken ~]# mkdir /ken

创建用于运行rsync进程的用户

[root@ken ~]# useradd -r -s /sbin/nologin -u  kenken

修改属主和数组

[root@ken ~]# chown -R kenken.kenken /ken

查看rsync的文件,/etc/rsyncd.conf,此文件默认不存在,需要自己手工写。

[root@ken ~]# rpm -ql rsync
/etc/rsyncd.conf
/etc/sysconfig/rsyncd
/usr/bin/rsync
...

创建rsync配置文件

[root@ken ~]# vim /etc/rsyncd.conf
pid file=/var/lock/subsys/pidfile
lock file=/var/lock/subsys/rsync
log file=/var/log/rsync
uid=
gid=
timeout=
max connections=
[ken]
path=/ken
list=yes
use chroot=yes
read only=no
auth users=user1
secrets file=/etc/rsyncd.pwd
hosts allow=172.20.10.8/

创建虚拟用户文件

[root@ken ~]# echo "user1:123">>/etc/rsyncd.pwd

修改权限为600

[root@ken ~]# chmod  /etc/rsyncd.pwd 

启动rsync服务

[root@ken ~]# rsync --daemon
[root@ken ~]# ss -tnl | grep
LISTEN *: *:*
LISTEN ::: :::*

4.配置inotify服务端

下载inotify需要配置epel仓库,复制如下代码到你的yum配置文件里面即可

[ken]
name=ken
enabled=
gpgcheck=
baseurl=https://mirrors.aliyun.com/epel/7Server/x86_64/

下载inotify

[root@ken ~]# yum install rsync inotify-tools -y

创建需要备份数据的目录

[root@ken ~]# mkdir /kenken

创建一个保存rsync虚拟用户和密码的文件并更改权限为600

[root@ken ~]# echo "" >>/etc/rsync.pwd
[root@ken ~]# chmod /etc/rsync.pwd

创建自动化监控备份脚本

[root@ken ~]# vim authbak.sh
#!/bin/bash
prog="inotifywait"
events="create,delete,close_write"
opt="-mrq"
dir="/kenken"
remote_host="172.20.10.7"
anon_user="user1"
mod_name="ken"
pwd_file="/etc/rsync.pwd"
$prog $opt -e $events --format "%w%f" $dir | while read line
do
rsync -rz --delete $dir $anon_user@$remote_host::$mod_name --password-file=$pwd_file
done

客户端运行脚本

[root@ken ~]# nohup bash authbak.sh &

5.在客户端进行测试

客户端创建文件测试

[root@ken kenken]# touch {..}.txt
[root@ken kenken]# ls
.txt 1.txt .txt .txt .txt .txt .txt .txt .txt .txt

在rsync服务器端查看是否有相同文件

[root@ken ken]# ls
.txt .txt .txt .txt .txt .txt .txt .txt .txt .txt

测试成功!

客户端删除文件测试

[root@ken kenken]# rm -rf .txt .txt 
[root@ken kenken]# ls
10.txt 2.txt 3.txt 5.txt 6.txt 7.txt 8.txt 9.txt

在rsync服务器端查看文件是否也已经被删除

[root@ken kenken]# ls
.txt .txt .txt .txt .txt .txt .txt .txt

测试成功!

至此我们已经可以实现全网自动化, 无差异化数据备份了。

rsync+inotify实现全网自动化数据备份-技术流ken的更多相关文章

  1. rsync+inotify实现全网自动化数据备份

    第1章 环境配置 实例1-1 服务器及IP主机名规划 已知 4 台服务器主机名主机对应信息见下表: 服务器说明 外网 IP(NAT) 内网 IP(NAT)  主机名 web服务器 10.0.0.7/2 ...

  2. 网站集群架构(LVS负载均衡、Nginx代理缓存、Nginx动静分离、Rsync+Inotify全网备份、Zabbix自动注册全网监控)--技术流ken

    前言 最近做了一个不大不小的项目,现就删繁就简单独拿出来web集群这一块写一篇博客.数据库集群请参考<MySQL集群架构篇:MHA+MySQL-PROXY+LVS实现MySQL集群架构高可用/高 ...

  3. Docker数据卷Volume实现文件共享、数据迁移备份(三)--技术流ken

    前言 前面已经写了两篇关于docker的博文了,在工作中有关docker的基本操作已经基本讲解完了.相信现在大家已经能够熟练配置docker以及使用docker来创建镜像以及容器了.本篇博客将会讲解如 ...

  4. zabbix实现百台服务器的自动化监控--技术流ken

    前言 最近有小伙伴通过Q联系到我说:公司现在有百多台服务器,想要部署zabbix进行监控,怎么实现自动化全网监控? 本篇博客将讲解一个我工作时做的一个实际项目,现在写出来供大家以后参考使用. 实现自动 ...

  5. Redis基础知识补充及持久化、备份介绍(二)--技术流ken

    Redis知识补充 在上一篇博客<Redis基础认识及常用命令使用(一)--技术流ken>中已经介绍了redis的一些基础知识,以及常用命令的使用,本篇博客将补充一些基础知识以及redis ...

  6. 进阶!基于CentOS7系统使用cobbler实现单台服务器批量自动化安装不同版本系统(week3_day5_part2)-技术流ken

    前言 在上一篇博文<cobbler批量安装系统使用详解-技术流ken>中已经详细讲解了cobbler的使用以及安装,本篇博文将会使用单台cobbler实现自动化批量安装不同版本的操作系统. ...

  7. cobbler单台服务器实现批量自动化安装不同版本系统-技术流ken

    前言 在上一篇博文<cobbler批量安装系统使用详解-技术流ken>中已经详细讲解了cobbler的使用以及安装,本篇博文将会使用单台cobbler实现自动化批量安装不同版本的操作系统. ...

  8. 学会这个删库再也不用跑路了~ --技术流ken

    前言 相信每一个学IT的人或多或少都听说过从删库到跑路这个梗~下图也是在各种交流群屡禁不止,新人听着也是瑟瑟发抖. 人们茶余饭后,街头巷角难免要问... 下面技术流ken就教给各位新手们一招删库再也不 ...

  9. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(二)--技术流ken

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)--技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个 ...

随机推荐

  1. android:动态申请权限(一)

    环境: android版本6.0 对应SDK版本23 动态申请权限说明:所有动态申请的权限,必须在AndroidManifest.xml中进行声明 步骤 1.新建一个android工程 默认创建即可 ...

  2. [转] C++中为什么要用指针,而不直接使用对象?

    原文点击这里 问题描述 我刚从 Java 转到使用 C++ 进行面向对象开发,我发现一个很让我非常困惑的问题:C++ 中经常出现使用对象指针,而不是直接使用对象本身的代码,比如下面这个例子: C++ ...

  3. 在注册表中查看Windows10系统激活密钥的方法

      1 2 3 4 5 6 7 分步阅读 百度经验:jingyan.baidu.com 激活Windows10系统(非自己使用激活密钥激活的系统)以后,我们不一定清楚激活密钥是什么.如果想查看自己电脑 ...

  4. git安装以及初始化

    安装文档参见:https://www.cnblogs.com/ximiaomiao/p/7140456.html 注意:安装成功后,用cmd进行基本信息设置时,当出现“git不是内部或外部命令,也不是 ...

  5. MFC中线程相关知识

    MFC中把线程分为两种类型,UI线程和工作者线程. MFC中启动一个线程的最好方法是调用AfxBeginThread,有两个版本,一个用于启动Ui线程,另外一个用于启动工作者线程.在MFC程序中,只有 ...

  6. EBS API及接口清单

    https://www.cnblogs.com/lizicheng/p/9521742.html 模块 应用场景 类型 API/接口 AP 付款核销 API ap_pay_invoice_pkg.ap ...

  7. java web spring 发送邮件

    package com.ws.common.mail; import java.io.File; import javax.mail.internet.MimeMessage; import java ...

  8. [编译] 2、minGW gcc在windows搭建编译win32程序环境

    1.普通下载一个MinGW程序.安装之后可以直接将MinGW目录拷贝到总工程的tool里面: demo_mesh_common tree -L 2 . ├── app ├── bin ├── buil ...

  9. Jenkins可用环境变量列表以及环境变量的使用(Shell/Command/Maven/Ant)

    一.可用环境变量列表(以下来自google翻译): BRANCH_NAME 对于多分支项目,这将被设置为正在构建的分支的名称,例如,如果您希望从而master不是从特征分支部署到生产. CHANGE_ ...

  10. Dubbo 源码分析 - 服务导出

    1.服务导出过程 本篇文章,我们来研究一下 Dubbo 导出服务的过程.Dubbo 服务导出过程始于 Spring 容器发布刷新事件,Dubbo 在接收到事件后,会立即执行服务导出逻辑.整个逻辑大致可 ...