当前位置: 首页 > news >正文

【Linux】rsync远程数据同步工具使用

一、rsync工具介绍

        rsync是一个用于在本地或远程系统之间同步文件和目录的工具。它通过比较源和目标文件的元数据(例如修改时间和大小)来确定需要同步的内容,然后仅传输必要的数据进行更新,从而实现高效的同步操作。

        rsync有如下特性:

  1. 可以镜像保存整个目录树和文件系统
  2. 可以增量同步数据,文件传输效率高,因而同步时间很短。
  3. 可以保持原有文件的权限、时间等属性。
  4. 加密传输数据,保证了数据的安全性。

二、rsync的client/server模式

        client/server模式下,是在server端启动一个服务端口,然后客户端来连接这个端口,默认873端,进行数据的同步和传输。

2.1 服务端设置

[root@hadoop01 ~]# yum install rsync -y
[root@hadoop01 ~]# vi /etc/rsyncd.conf
#指定传输文件时守护进程应该具有的用户ID,默认值是“nobody”
uid = nobody
#指定传输文件时守护进程应该具有的用户组ID,默认值为“nobody”
gid = nobody
#是否限定在该目录下,有软连接需要用no
use chroot = no
#指定模块的最大并发连接数量,以保护服务器,超过限制的连接请求,将被暂时限制。默认值是0,也就是没有限制。
max connections = 10
#pid路径
pid file = /var/run/rsyncd.pid
#锁文件路径
lock file = /var/run/rsync.lock
#日志输出路径
log file = /var/log/rsyncd.log#定义一个模块,weiyun为模块名称
[weiyun]
#指定同步的路径
path = /data
#模块描述
comment = ixdba file
#在同步过程中遇到错误时继续执行而不中断
ignore errors
#是否只读,如果客户端需要推送给服务端,改为yes
read only = true
#当客户请求可以使用的模块列表时,该模块是否被列出。默认值是true,如果需要建立隐藏的模块。可以设置为false。
list = false
#指定传输文件时守护进程应该具有的用户ID
uid = root
#指定传输文件时守护进程应该具有的组ID
gid = root
#定义可以连接该模块的用户名,多个用户用空格或逗号分隔开。需要注意的是这里的用户和Linux系统用户没有任何关系。这里指定的用户是backup
auth users = backup
#指定一个包含“用户名:密码”格式的文件,用户名就是“auth users”选项定义的用户,密码可以随便指定,只要和客户端的secrets file对应起来就行。只有在auth users被定义时,该文件才起作用。系统默认没有这个文件,自己手动创建一个即可。
secrets file = /etc/rsync.password#配置密码文件
[root@hadoop01 ~]# vi /etc/rsync.password
#backup对应配置文件里的auth users
backup:123456
[root@hadoop01 ~]# chmod 700 /etc/rsync.password#启动rsync
[root@hadoop01 ~]# systemctl start rsyncd

2.2 客户端同步

[root@hadoop02 ~]# yum install rsync -y
#设置客服端账号密码,如果不设置,同步时手动输入密码即可
[root@hadoop02 ~]# vi /etc/rsync.password
123456
[root@hadoop02 ~]# chmod 700 /etc/rsync.password#同步服务端的数据
[root@hadoop02 ~]# rsync -vzrtopg --delete --progress backup@192.168.10.200::weiyun  /data --password-file=/etc/rsync.password

“--vzrtopg”选项中v是“-verbose”,即详细模式输出,z表示“--compress” 即对备份的文件在传输时进行压缩处理,r表示“--recursive”,也就是对子目录以递归模式处理。t即“--times”,用来保持文件时间信息,o即“--owner”用来保持文件属主信息。p即“--perms”用来保持文件权限,g即“--group”用来保持文件的属组信息。

 “--delete”选项指定以rsync服务端为基准进行数据镜像同步,也就是要保持rsync服务端目录与客户端目录的完全一致性。

 “--progress”选项用于显示数据镜像同步的过程。

 “backup@192.168.60.253::weiyun” 表示对服务器192.168.10.200的weiyun模块进行备份,也就是指定备份的模块,backup表示使用“backup”这个用户对该模块进行备份。

“/data”用于指定备份文件在客户端机器上的存放路径,也就是将备份的文件存放在备份机的/data目录下。

 “--password-file=/etc/server.pass”用来指定客户机上存放的密码文件位置,这样在客户端执行同步命令时就无需输入交互密码了,注意,这个密码文件的名称和位置可以随意指定,但是在客户机上必须存在此文件,文件的内容仅仅为备份用户的密码,这里指的是backup的密码。

三、rsync的client/client模式

#推送模式,root为192.168.10.200的用户
[root@hadoop02 ~]# rsync -vzrtopg --delete --progress   /data root@192.168.10.200:/data
#拉取模式,root为192.168.10.200的用户
[root@hadoop02 ~]# rsync -vzrtopg --delete --progress  root@192.168.10.200:/data /data#默认情况下rsync走的是ssh协议,22端口,如果ssh是非默认的22端口,那么可以添加“-e“选项:
rsync -vzrtopg --delete --progress -e 'ssh -p 9090' /data root@172.16.213.233:/data (推送模式)
rsync -vzrtopg --delete --progress -e 'ssh -p 9090' root@172.16.213.233:/data /data(拉取模式)
其中,9090是sshd服务的端口。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 新品发布 | 飞凌嵌入式RK3576核心板,为AIoT应用赋能
  • 网络基础-IP协议
  • git 下载openNeuro大文件
  • frida hook微信防撤回(PC端)
  • Rust-03-数据类型
  • 【前端】详解JavaScript事件代理(事件委托)
  • ---java 抽象类 和 接口---
  • 【设计模式】行为型设计模式之 迭代器模式
  • LeetCode 算法:合并区间c++
  • 封装了一个简单理解的iOS竖直文字轮播
  • k8s学习--kubernetes服务自动伸缩之水平收缩(pod副本收缩)VPA策略应用案例
  • Wireshark TS | 应用传输丢包问题
  • No ‘ChromeSansMM’ font 错误解决
  • 渗透测试之内核安全系列课程:Rootkit技术初探(一)
  • vue面试题2-根据以下问题回答
  • 【翻译】babel对TC39装饰器草案的实现
  • Java 网络编程(2):UDP 的使用
  • ReactNativeweexDeviceOne对比
  • scala基础语法(二)
  • Spring Cloud(3) - 服务治理: Spring Cloud Eureka
  • vue从创建到完整的饿了么(18)购物车详细信息的展示与删除
  • vue自定义指令实现v-tap插件
  • 从0实现一个tiny react(三)生命周期
  • 多线程 start 和 run 方法到底有什么区别?
  • 坑!为什么View.startAnimation不起作用?
  • 名企6年Java程序员的工作总结,写给在迷茫中的你!
  • 漂亮刷新控件-iOS
  • 深入体验bash on windows,在windows上搭建原生的linux开发环境,酷!
  • 一道闭包题引发的思考
  • ​浅谈 Linux 中的 core dump 分析方法
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • #Linux(帮助手册)
  • #pragma once与条件编译
  • #如何使用 Qt 5.6 在 Android 上启用 NFC
  • (6)【Python/机器学习/深度学习】Machine-Learning模型与算法应用—使用Adaboost建模及工作环境下的数据分析整理
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (ZT) 理解系统底层的概念是多么重要(by趋势科技邹飞)
  • (二十四)Flask之flask-session组件
  • (附源码)springboot教学评价 毕业设计 641310
  • (附源码)springboot猪场管理系统 毕业设计 160901
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (微服务实战)预付卡平台支付交易系统卡充值业务流程设计
  • (转)ObjectiveC 深浅拷贝学习
  • . NET自动找可写目录
  • .axf 转化 .bin文件 的方法
  • .env.development、.env.production、.env.staging
  • .NET CORE 第一节 创建基本的 asp.net core
  • .NET/C# 在代码中测量代码执行耗时的建议(比较系统性能计数器和系统时间)...
  • .Net6 Api Swagger配置
  • .net安装_还在用第三方安装.NET?Win10自带.NET3.5安装
  • .NET单元测试
  • .net的socket示例
  • [AIGC] HashMap的扩容与缩容:动态调整容量以提高性能
  • [Android学习笔记]ScrollView的使用
  • [AutoSar]BSW_Com02 PDU详解