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

posted @ 2022-02-17 22:12  Zix-  阅读(124)  评论(0编辑  收藏  举报