Rsync实现服务器数据备份
Rsync 是 Linux 系统下的数据镜像备份工具,使用快速增量备份工具 Remote Sync 可以远程同步,可以在不同主机之间进行同步,可实现全量备份与增量备份,保持链接和权限,传输前执行压缩,因此非常适合用于架构集中式备份或异地备份等应用。
官方网站:https://rsync.samba.org/
与 SCP 的比较:scp 无法备份大量数据,类似 Windows 的复制。而 rsync 边复制,边统计,边比较。
- Rysnc 特性和优点
- 可以镜像保存整个目录树和文件系统。
- 可以很容易做到保持原来文件的属性、权限、时间、软硬链接等等。
- 无须特殊权限即可安装。
- 快速:第一次同步时 rsync 复制全部内容,但在下一次只传输修改过的文件。
- 压缩传输:rsync 在传输数据的过程中可以实行压缩及解压缩操作,因此可以使用更少的带宽。
- 安全性:可以使用 scp、ssh 等方式来传输文件,当然也可以通过直接的 socket 连接。选择性保持:符号连接,硬链接,文件属性,权限,时间等。
- 常见备份分类
- 完整备份:每次都备份所有数据。
- 差异备份:每次备份和第一次完全备份相比的“差异”部分数据。
- 增量备份:除第一次备份以外,每次只备份增长数据。
- RSYNC 原理
运行模式和端口:
采用 C/S 模式(客户端/服务器模式)[ 实际上是一个点到点的传输,直接使用 rsync 命令即可完成 ]
rsync 监听的端口:873 - 四个名词的解释:
发起端:负责发起 rsync 同步操作的客户机叫做发起端,通知服务器我要备份你的数据。
备份源:负责响应来自客户机 rsync 同步操作的服务器叫做备份源,需要备份的服务器。
服务端:运行 rsyncd 服务,一般来说,需要备份的服务器。
客户端:存放备份数据。
- 数据同步方式:
- 推 push:一台主机负责把数据传送给其他主机,服务器开销很大,比较适合后端服务器少的情况。
拉 pull:所有主机定时去找一台主机拉数据,可能就会导致数据缓慢。 - 从 数据源服务器 往 备份服务器 push (推,相当于备份操作)
- 从 数据源服务器 往 备份服务器 pull (拉,相当于还原操作)
- 推:目的主机配置为 rsync 服务器,源主机周期性的使用 rsync 命令把要同步的目录推过去(需要备份的机器是客户端,存储备份的机器是服务端)。
- 拉:源主机配置为 rsync 服务器,目的主机周期性的使用 rsync 命令把要同步的目录拉过来(需要备份的机器是服务端,存储备份的机器是客户端)。
两种方案,rsync 都有对应的命令来实现
rsync 命令示例说明 push 和 pull
- CentOS 7 系统之前 xinetd 管理 Rsync 工作原理
- 使用 rsync 来同步是先通过 xinetd 监听 873 号端口,如果 rsync 进来的是 873 号端口,那么xinetd 就会通知它所管辖的 rsync 服务来做回应,接下来就是 rsync 俩服务于之间的通讯。
原文参考链接:https://blog.csdn.net/gaofei0428/article/details/117061853