小白带你学习Linux的rsync的基本操作(二十四)

目录

前言

一、概述

二、特性

1、快速

2、安全

三、应用场景

四、数据的同步方式

五、rsync传输模式

六、rsync应用

七、rsync命令

1、格式

2、选项

3、举例

4、配置文件

5、练习

八、rsync+inotfy实时同步

1、服务器端

2、开发客户端


前言

Rsync是一个开源的文件同步和备份工具。它可以通过局域网或互联网将文件从一个地方同步到另一个地方,保持两个位置的文件内容一致。Rsync在传输文件时仅传输文件的变化部分,而不是整个文件,这样可以大大加快文件传输的速度。

一、概述

    rsync是linux 下一个远程数据同步工具

    他可通过LAN/WAN快速同步多台主机间的文件和目录,并适当利用rsync 算法减少数据的传输

    会对比两个文件的不同部分,传输差异部分,因此传输速度相当快

    rsync可拷贝、显示目录属性,以及拷贝文件,并选择性的压缩及递归拷贝

二、特性

1、快速

第一次传输全部,下一次传输差异

 rsync在传输过程中可以实行压缩和解压缩,使用更少的带宽

2、安全

 可以使用scp、ssh等方式传输

 直接通过socket连接

 支持匿名传输、方便进行网站镜像

三、应用场景

增量同步

备份迁移

四、数据的同步方式

数据备份:拉取(下载)

pull

数据恢复:推送(上传)

 push

五、rsync传输模式

本地传输

本地同步数据,类似于cp

远程传输

远程同步数据,类似于scp

守护进程

通过模块化的方式实现批量传输

六、rsync应用

安装

yum -y install rsync

如果已经安装,直接启动

第一步关防火墙和改宽容模式

systemctl stop firewalld && systemctl disable firewalld
setenforce 0

rpm -qi rsync

systemctl start rsyncd

监听端口号

 TCP/873

netstat -anptl | grep rsync

七、rsync命令

1、格式

rsync [选项] 原始位置 目标位置

作为远程命令

拉取                rsync [OPTION...] [USER@]HOST:SRC... [DEST]

rsync 1.txt 192.168.28.129:/mnt

推送                rsync [OPTION...] SRC... [USER@]HOST:DEST

作为rsync服务

拉取                rsync [OPTION...] [USER@]HOST::SRC... [DEST]

                       rsync [OPTION...] rsync://[USER@]HOST[:PORT]/SRC... [DEST]

 推送             rsync [OPTION...] SRC... [USER@]HOST::DEST

                      rsync [OPTION...] SRC... rsync://[USER@]HOST[:PORT]/DEST

2、选项

-a           归档模式,递归并保留对象属性,等同于-rlptgoD

-v           -verbose           显示同步过程的详细信息

-z           在传输文件时进行压缩

3、举例

本地

rsync  -avz  abc/  /opt

远程

rsync -avz root@192.168.28.129:/opt

rsync -avz 1.txt  root@192.168.28.129:/opt

4、配置文件

/etc/rsyncd.conf

全局配置

address    独立运行时,用于指定服务器运行的 IP 地址,默认本地所有IP

port       指定 rsync 守护进程监听的端口号,默认 873

pid file     rsync 的守护进程将其 PID 写入指定的文件

log file     指定 rsync 守护进程的日志文件,而不将日志发送给 syslog

syslog facility   指定 rsync 发送日志消息给 syslog 时的消息级别

socket options  指定自定义 TCP 选项

lockfile   指定rsync的锁文件存放路径

timeout    超时时间

模块配置

path       指定当前模块的同步路径,该参数是必须指定的

comment   给模块指定一个描述

use chroot           在服务运行时要不要把他锁定在家目录,默认为 true

uid和gid            指定rsync运行用户和用户组,默认nobody

max connections      最大并发连接数,0为不限制

lock file             指定支持 max connections的锁文件。默认/var/run/rsyncd.lock

list                 指定列出模块列表时,该模块是否被列出。默认为 true

read only          只读选择,默认true

write only         只写选择,不让客户端从服务器上下载文件。默认false

ignore errors     忽略IO错误,默认true

ignore nonreadable 指定 rysnc 服务器完全忽略那些用户没有访问权限的文件。

dont compress      用来指定那些在传输之前不进行压缩处理的文件。

hosts allow  指定哪些主机客户允许连接该模块。默认值为 *

hosts deny  指定哪些主机客户不允许连接该模块

auth users   指定用于上传的用户名

secrets files    指定密码文件

守护进程传输

配置

uid=rsync

gid=rsync

fake super=yes     # 用于允许非root用户,在备份目录创建文件

list=false              # 默认true,允许查看本机有哪些模块

auth users=rsync_backup  # 用于指定认证用户

secrets file=/etc/rsync.passwd  # 指定认证用户密码

max connections=4                 # 允许最大连接数

read only=false                       # 默认yes,模块目录只读权限

ignore errors                          # 屏蔽错误报错

timeout=900                          # 指定rsync传输超时时间

[backup]

 path=/backup

vim /etc/rsyncd.conf

 创建用户        useradd rsync -s /sbin/nologin -M

useradd rsync -s /sbin/nologin -M rsync

创建认证用户的密码        echo 'rsync_backup:123456' >/etc/rsync.passwd

                                         chmod 600 /etc/rsync.passwd

 echo 'rsync_backup:123456' >/etc/rsync.passwd
   chmod 600 /etc/rsync.passwd

准备模块目录          mkdir /backup

                                 chown rsync.rsync /backup

mkdir /backup
  chown rsync.rsync /backup

重启服务          systemctl restart rsyncd

systemctl restart rsyncd

客户端远程传输            rsync -avz /etc/hosts rsync_backup@192.168.2.62::backup

  rsync -avz /etc/hosts rsync_backup@192.168.28.128::backup

查看一下文件

回到客户端进入 

插入信息

 再上传一遍

 服务器查看

 这就是手动服务同步

通过密码文件实现免密传输

vim /etc/rsync.passwd             123456

vim /etc/rsync.passwd  

chmod   600 /etc/rsync.passwd

chmod   600 /etc/rsync.passwd

 rsync -avz /etc/hosts rsync_backup@192.168.2.62::backup --password-file /etc/rsync.passwd

5、练习

1、使用认证用户为jx_名字缩写,认证密码为班级编号

/etc/rsyncd.conf

2、模块名称为juexing

重启服务 

3、客户端创建文件user.txt,内容为所有的用户信息

客户端先传过去看看

 服务器查看

4、自行修改文件内容,在服务器上实现同步

 删除剩四行

同样的命令在执行

 回到服务器

八、rsync+inotfy实时同步

1、服务器端

安装网站服务,启动,但是不写首页文件

安装httpd

mount  /dev/sr0 /mnt
yum -y install httpd

 

修改主配置文件

uid = root

gid = root

[wwwroot]

    path = /var/www/html

    comment = backup export area

    read only = false

    hosts allow = 192.168.1.0/24

vim /etc/rsyncd.conf

2、开发客户端

安装inotify工具

inotify-tools

tar xf  inotify-tools-3.14.tar.gz

./configure && make && make install

搭建网站服务器 

 查看端口号

 配置内核参数

vim /etc/sysctl.conf

fs.inotify.max_user_instances = 1024

fs.inotify.max_queued_events = 16384

fs.inotify.max_user_watches=1048576

sysctl -P

inotifywait -mrq -e modify,create,move,delete /var/www/html

 把客户端的wwwroot传回服务器

 回主机查看

 回客户端


 再传一遍

 回主机

编写脚本

#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e modify,create,attrib,move,delete /var/www/html/"
RSYNC_CMD="rsync -azH --delete /var/www/html/ 192.168.28.128::wwwroot"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
$RSYNC_CMD
done

 客户机改文件

 回服务器查看一下

赋予执行权限 

chmod +x inotify_rsync.sh

写入文件开机自启文件

vim /etc/rc.local

/root/inotify_rsync.sh

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/29584.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux 安装oracle_11g保姆级安装教程及安装Oracle常见问题处理

一 安装linux 1 Linux系统 安装前的准备 linux安装建议: 1)脑内存1G,交换空间是物理内存的两倍,空闲空间(/tmp目录)至少1G 2)选择服务时,建议全部选中,关闭防火墙&am…

python实现正态分布变换NDT算法(notebook版本)

直接看notebook,写的应该很清楚了 准备数据 假设两帧机器人相对位置变化如下 采集得到两帧点云 构建得分地图 优化点云位姿 红色为初值,蓝色为优化结果,可以看出NDT算法对初值要求不高。

标注工具Labelimg,正常运行显示,但是对图片点击Create RectBox画矩形框开始闪退

问题描述*:标注工具Labelimg,正常运行显示,但是对图片点击Create RectBox画矩形框开始闪退,闪退出现以下代码 File “C:\ProgramData\anaconda3\Lib\site-packages\libs\canvas.py”, line 530, in paintEvent p.drawLine(self.p…

图采样、随机游走、subgraph的实现

诸神缄默不语-个人CSDN博文目录 本博文主要关注如何用代码实现图采样、随机游走、subgraph(为什么这些东西放在一起写,我感觉还蛮直觉的)。 随机游走和subgraph我之前都写过不少博文了,可以参考↑ 这个主要是我前年还在干GNN时候…

Hugging Face开源库accelerate详解

官网:https://huggingface.co/docs/accelerate/package_reference/accelerator Accelerate使用步骤 初始化accelerate对象accelerator Accelerator()调用prepare方法对model、dataloader、optimizer、lr_schedluer进行预处理删除掉代码中关于gpu的操作&#xff0…

Windows11 C盘瘦身

1.符号链接 将大文件夹移动到其他盘,创建成符号链接 2.修改Android Studio路径设置 1.SDK路径 2.Gradle路径 3.模拟器路径 设置环境变量 ANDROID_SDK_HOME

五、DQL-1.概述

一、DQL介绍 Data Query Language 数据查询语言 用来查询数据库中表的记录。 查询关键字:SELECT 二、语法

每日一题2023.7.19|ACM模式

文章目录 C的输入方式介绍cin>>cin.get(字符变量名)cin.get(数组名,接收字符数目)cin.get()cin.getline() getline()gets()getchar() AB问题|AB问题||AB问题|||ABⅣAB问题ⅤAB问题Ⅵ C的输入方式介绍 参考博客 cin>> 最基本,最常用的字符或者数字的输…

Ceph 分布式存储之部署

一.Ceph 存储基础 1、单机存储设备 DAS(直接附加存储,是直接接到计算机的主板总线上去的存储) IDE、SATA、SCSI、SAS、USB 接口的磁盘 所谓接口就是一种存储设备驱动下的磁盘设备,提供块级别的存储 NAS(网络附加存储…

ES系列--文档处理

一、文档冲突 当我们使用 index API 更新文档 ,可以一次性读取原始文档,做我们的修改,然后重 新索引 整个文档 。 最近的索引请求将获胜:无论最后哪一个文档被索引,都将被唯一存 储在 Elasticsearch 中。如果其他人同时…

云计算名词-IaaS,PaaS,SaaS

在学习分布式的过程中,知道了PaaS这个词儿,但是不知道是什么意思。从网上查询了之后,做了简单的了解。这里简单记录一下,方面之后的查阅。 IAAS(Infrastructure-as-a-Service)基础设施即服务 网上的定义是…

13matlab数据分析多项式的求值(matlab程序)

1.简述 统计分析常用函数 求最大值 max 和 sum 积 prod 平均值:mean 累加和:cumsum 标准差:std 方差:var 相关系数:corrcoef 排序:sort 四则运算 1.多项式的加减运算就是所对应的系数向量的加减运算&#…