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

rsync 命令以及脚本使用

rsync是什么?

rsync 是一个远程同步工具

下载

你的集群每一台都需要下载!(也就是你需要同步的机器)

yum install -y xsync

如果其他不下载就是报错的这样(使用脚本的情况下,注意这里是提示 rsync没有找到,不是xsync)

[root@master bin]# xsync /opt/test/
==================== master ====================
sending incremental file listsent 97 bytes  received 17 bytes  76.00 bytes/sec
total size is 10  speedup is 0.09
==================== slave1 ====================
bash: rsync: 未找到命令
rsync: connection unexpectedly closed (0 bytes received so far) [sender]
rsync error: remote command not found (code 127) at io.c(226) [sender=3.1.2]
==================== slave2 ====================
bash: rsync: 未找到命令
rsync: connection unexpectedly closed (0 bytes received so far) [sender]
rsync error: remote command not found (code 127) at io.c(226) [sender=3.1.2]

优点与scp对比

优点:rsync主要用于备份和镜像。具有速度快、避免复制相同内容和支持符号链接的优点。
与scp对比:rsync 要比scp复制速度快,因为 rsync 是复制有差异性的文件(它会自己检查),而scp 则是把所有的文件统一复制过去,达到的是一个 统统覆盖的意义

纯命令 Chat- GPT-3.5 演示:

rsync 是一个用于文件同步和备份的工具,可以在本地或远程系统之间高效地进行文件的复制和同步。以下是 rsync 命令的基本用法示例以及一些常用选项:

rsync [options] source destination
其中 source 表示源文件或目录的路径,destination 表示目标文件或目录的路径。

常用的选项包括:

-a:归档模式,用于保持文件的属性、权限和时间等。
-v:详细输出模式,显示正在复制的文件和目录。
-r:递归复制目录及其内容。
-z:传输时压缩数据,可以减少传输时间。
--delete:删除目标中不存在于源的文件。
--exclude:排除指定的文件或目录。
-e:指定远程 shell 的路径,通常用于远程传输。

以下是一些示例:

本地文件同步:

rsync -av /path/to/source /path/to/destination

本地目录同步:

rsync -av /path/to/source/ /path/to/destination/

从本地到远程服务器同步:

rsync -av /path/to/source username@remote_server:/path/to/destination

从远程服务器到本地同步:

rsync -av username@remote_server:/path/to/source /path/to/destination

同步时排除特定文件或目录:

rsync -av --exclude='*.log' /path/to/source /path/to/destination

使用压缩传输:

rsync -avz /path/to/source /path/to/destination

请注意,rsync 的选项和用法非常丰富,你可以根据需要进行组合和定制。在使用之前,建议查阅相关文档或执行 man rsync 命令来获取更详细的信息和帮助。

脚本

脚本来自这位仁兄: https://blog.csdn.net/qq_63756815/article/details/127016471
1、在 /bin 目录下创建 xsync文件脚本
2、需要修改的是在 第二步,修改为自己的主机名
3、修改 文件权限为 777,也可以单加一个可执行权限(x):
chmod 777 xsync
4、

#!/bin/bash#1. 判断参数个数
if [ $# -lt 1 ]
thenecho Not Enough Arguement!exit;
fi#2. 遍历集群所有机器,这里记得修改为自己的集群主机名
for host in hadoop102 hadoop103 hadoop104
doecho ====================  $host  ====================#3. 遍历所有目录,挨个发送for file in $@do#4. 判断文件是否存在if [ -e $file ]then#5. 获取父目录pdir=$(cd -P $(dirname $file); pwd)#6. 获取当前文件的名称fname=$(basename $file)ssh $host "mkdir -p $pdir"rsync -av $pdir/$fname $host:$pdirelseecho $file does not exists!fidone
done

演示:
脚本:

[root@master bin]# xsync /opt/test/
==================== master ====================
sending incremental file listsent 97 bytes  received 17 bytes  76.00 bytes/sec
total size is 10  speedup is 0.09
==================== slave1 ====================
sending incremental file list
test/
test/a1.txt
test/a2.txtsent 200 bytes  received 58 bytes  172.00 bytes/sec
total size is 10  speedup is 0.04
==================== slave2 ====================
sending incremental file list
test/
test/a1.txt
test/a2.txtsent 200 bytes  received 58 bytes  516.00 bytes/sec
total size is 10  speedup is 0.04

纯命令:

[root@master bin]# echo 2222 > /opt/test/a2.txt 
[root@master bin]# rsync -av /opt/test/ slave1:/opt/test/
sending incremental file list
a2.txtsent 137 bytes  received 41 bytes  118.67 bytes/sec
total size is 10  speedup is 0.06

这里 我专门试了试会不会自动给我创建目录(因为我没学过脚本),发现是会的
但是 如果是纯命令的话,你必须和scp命令相同的语法,就是绝对路径,且只会复制文件

相关文章:

rsync 命令以及脚本使用

rsync是什么? rsync 是一个远程同步工具 下载 你的集群每一台都需要下载!(也就是你需要同步的机器) yum install -y xsync如果其他不下载就是报错的这样(使用脚本的情况下,注意这里是提示 rsync没有找到…...

【数理知识】协方差,随机变量的的协方差,随机变量分别是单个数字和向量时的协方差

序号内容1【数理知识】自由度 degree of freedom 及自由度的计算方法2【数理知识】刚体 rigid body 及刚体的运动3【数理知识】刚体基本运动,平动,转动4【数理知识】向量数乘,内积,外积,matlab代码实现5【数理知识】协…...

WebDAV之π-Disk派盘+可达漫画

可达漫画这是一款专为阅读你的漫画收藏而设计的阅读器。 热爱漫画的你肯定收藏了不少各种类型的漫画,它们可能有各种各样的格式,zip,rar,cbz,cbr,epub, mobi 或 pdf,也可能只是单纯的文件夹。 可达漫画支持「流式阅读」,如果你的服务器使用 WebDAV 或 SMB 协议,那么…...

Spring中Bean的线程安全问题

Spring框架本身没有明确指出Bean的线程安全问题,所以Bean本身也不具备线程安全的特性,具体情况得看scope的情况。 1.原型的(prototype) 每次创建一个新的对象,每个线程使用的对象都是要新创建的,所以不会存在线程安全的问题。 2…...

Java spring boot 全解Camunda 7,从 0 到 1 构建工作流平台——第二节:Spring boot 简单集成

目录 1. 成果展示2. 环境准备3. 项目构建3.1 项目结构3.2 引入Camunda 依赖3.3 启动spring boot 程序3.4 启动 web app 程序 引言:当今技术发展迅猛,企业对于业务流程的高效管理和自动化需求也日益增长。在这个背景下,Spring Boot和Camunda7成…...

手持式静电测试仪的运用原理

手持式静电测试仪(Handheld Electrostatic Test Meter)是一种用于测量和检测静电电荷的便携式设备。它通常用于工业生产、实验室研究、防静电控制和监测等领域。 手持式静电测试仪可以帮助用户快速准确地测量物体表面静电电荷的状态,从而评估…...

【css问题】flex布局中,子标签宽度超出父标签宽度,导致布局出现问题

场景:文章标题过长时,只显示一行,且多余的部分用省略号显示。 最终效果图: 实现时,flex布局,出现问题: 发现text-overflow: ellipsis不生效,省略符根本没有出现。 而且因为设置了 …...

【vue3】前端应用中使用WebSocket与服务器进行通信并管理连接状态。

1、写一个hook函数 export const useWebsocketToStore ({ onMessage }): any > {const url ws:地址 Math.random()const onConnected () > {}const onDisconnected () > {}const onError () > {}const onMessageDefault (ws: WebSocket, event: MessageEve…...

服务端高并发分布式结构演进之路

目录 一、常见概念 1.1基本概念 二、架构演进 2.1单机架构 2.2应用数据分离架构 2.3应用服务集群架构 2.4读写分离 / 主从分离架构 2.5引入缓存 —— 冷热分离架构 2.6垂直分库 2.7业务拆分 —— 微服务 一、常见概念 1.1基本概念 应用(Application&am…...

微服务基础总结

1.服务注册和发现 服务注册维护一个登记簿,管理系统内所有服务地址,服务启动后会向登记簿交待自己的地址信息。 服务注册形式:客户端注册和第三方注册 客户端注册(zookeeper) 服务自身要负责注册和注销工作&#xf…...

实现vscode上用gdb调试stm32

实现vscode上用gdb调试stm32 这周负责编写设备的某个模块,其中遇到了一些变量地址不正确的错误,按理这种底层变量错误用gdb一类的调试器就能很快查到,可是初入嵌入式一行,此C语言非彼C语言,对于gdb怎么对接到项目上根…...

第4章 变量、作用域与内存

引言 由于js是一门只有在声明变量后才能明确类型的语言,并且在任意时刻都可以改变数据类型。这也引起了一些问题 原始值与引用值 原始值就是基本数据类型,引言值就是复杂数据类型 变量在赋值的时候。js会判断如果是原始值,访问时就是按值访问…...

Python爬虫遇到重定向问题解决办法汇总

在进行Python爬虫任务时,遇到重定向问题是常见的问题之一。重定向是指在发送请求时,服务器会返回一个新的URL,将请求重新定向到该URL。为了帮助您解决这个问题,本文将提供一些实用的解决办法,并给出相关的代码示例&…...

R并行计算

1-lapply()函数介绍: 为什么介绍这个函数呢?因为在windows中使用parLapply()函数和lapply()的结构和用法是非常相似的,我们只需要将原本用lapply(x, fun)迭代函数 直接改写成 parLapply(makeCluster(c1), x, fun)即可,这里的直接…...

STM32 低功耗-待机模式

STM32 待机模式 文章目录 STM32 待机模式第1章 低功耗模式简介第2章 待机模式简介2.1 进入待机模式2.1 退出待机模式 第3章 待机模式代码部分总结 第1章 低功耗模式简介 在 STM32 的正常工作中,具有四种工作模式:运行、睡眠、停止和待机模式。 在系统或…...

极海APM32F003F6P6烧写问题解决记录

工作中遇到的,折腾了好久,因为电脑重装过一遍系统,软件也都重新安装了,所以不知道之前的配置是什么,旧项目代码编译没问题,烧写时疯狂报错,用的是JLink。 keil版本v5.14 win10版本 JLink版本…...

【大数据】Flink 详解(一):基础篇

Flink 详解(一):基础篇 1、什么是 Flink ? Flink 是一个以 流 为核心的高可用、高性能的分布式计算引擎。具备 流批一体,高吞吐、低延迟,容错能力,大规模复杂计算等特点,在数据流上提…...

ChatGPT 作为 Python 编程助手

推荐:使用 NSDT场景编辑器 助你快速搭建可编辑的3D应用场景 简单的数据处理脚本 我认为一个好的起点是某种数据处理脚本。由于我打算让 ChatGPT 之后使用各种 Python 库编写一些机器学习脚本,这似乎是一个合理的起点。 目标 首先,我想尝试…...

饿了么输入框限制只能输入数字,并且保留小数

可以使用饿了么ui中的input-number组件实现输入框只能输入数字,这样就不能输入数字以外的,controls隐藏输入框左右俩边的加减按钮,precision小数点保留多少位,2则是俩位,但是会导致默认值为0.00的情况,俩种…...

kylin-Desktop gsettings 获取或设置系统配置

gsettings提供了对GSetings的命令行操作。GSetings实际上是一套高级API,用来操作dconf。 dconf存储着GNOME3的配置,是二进制格式。它做为GSettings的后端系统存在,暴露出低级API。在GNOME2时代,类似的角色是gconf,但它是以XML文本形式存储。 更接地气的说法是,dconf是G…...

不止于时钟:用QtE 4.4.0为UP-CUP4412开发板打造个性化嵌入式GUI界面的思路与扩展

从时钟到智能终端:基于QtE 4.4.0的UP-CUP4412嵌入式GUI开发实战 在嵌入式系统开发领域,图形用户界面(GUI)的设计与实现一直是连接硬件与用户的关键桥梁。UP-CUP4412开发板作为一款功能强大的ARM平台,配合Qt/Embedded(QtE)这一轻量级GUI框架&a…...

别再为CUDA版本发愁了!手把手教你用Anaconda+PyCharm在Windows上搞定YOLOv11完整开发环境

从零搭建YOLOv11开发环境:Windows下的CUDA避坑指南与EMA注意力实战 刚接触计算机视觉的新手们,是否曾在配置深度学习环境时被CUDA版本冲突、PyTorch安装失败等问题折磨得焦头烂额?本文将带你用Anaconda和PyCharm在Windows系统上搭建一个稳定…...

Vue微商城实战:从零搭建高效开发环境与核心配置

1. 环境准备:搭建Vue开发基础 第一次用Vue做微商城项目时,我对着官方文档折腾了半天环境配置,结果运行时报错一片红。后来才发现是node版本和脚手架不兼容的问题。这里分享下我总结的零失败配置方案,帮你避开90%的初期坑点。 首先…...

深入Linux内核:RDMA Verbs API的object/method/attr三层模型设计与实现解析

深入Linux内核:RDMA Verbs API的object/method/attr三层模型设计与实现解析 在当今高性能计算和分布式存储领域,远程直接内存访问(RDMA)技术因其极低的延迟和高吞吐量而备受青睐。作为RDMA技术的核心接口,Verbs API的设计哲学直接影响着整个生…...

SAMD平台轻量级事件驱动按钮库slight_ButtonInput

1. 项目概述 slight_ButtonInput 是一个面向嵌入式平台( 仅限 SAMD 系列微控制器 ,如 ATSAMD21G18、ATSAMD51J19 等)的轻量级 Arduino 库,专为 事件驱动型按钮输入处理 而设计。其核心目标并非简单轮询引脚电平,…...

Agent记忆架构从入门到精通:10种方案全解析,收藏这篇就够了!

继续看Agent记忆进展,看10种Agent记忆方案对比总结,可以借此机会,看看这些记忆系统在设计的时候都有哪些组件,有哪些优化策略,以及有哪些经验。【我们已经陆陆续续讲了多个了,也有一些综述,但拉…...

RL训练像点外卖?ProRL底层逻辑拆解(非常详细),从入门到精通看这篇!

一句话讲清楚👉🏻 NVIDIA提出ProRL Agent,把多轮LLM Agent的RL训练中「轨迹生成(Rollout)」这一步从训练框架中彻底剥离出来,变成一个独立的HTTP服务,训练侧只需发HTTP请求就能拿到轨迹和奖励信…...

新手必看:从零到一搞定CTFHub Web入门题(HTTP协议+信息泄露实战)

从零构建CTF Web安全实战能力:HTTP协议与信息泄露攻防指南 当你第一次接触CTF竞赛中那些看似神秘的Web题目时,是否感到无从下手?本文将带你系统掌握Web安全的两大基石——HTTP协议操纵与信息泄露挖掘,通过CTFHub实战平台构建完整的…...

C#基于S7.Net组件实现西门子PLC通信上位机功能说明

C#与西门子plc通讯上位机 c#软件 工控软件 1.该程可以实现CSharp与西门子全系列plc(200,200smart,300,1200,1500)的以太网s7通讯,通讯传输快稳定。 2.该程序采用s7以太网通讯方式,本人经过几个星期的测试&…...

1996-2024年全国各地区交通事故、火灾事故数据

资源介绍 交通事故与火灾事故是衡量区域公共安全水平与风险治理能力的重要客观指标,直接关系到居民生命财产安全、社会稳定以及政府公共治理绩效。从研究视角看,事故类数据不仅反映突发性风险事件的发生频率,也在一定程度上刻画了区域基础设施…...