Rsync(二十七)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

前言

一、概述

二、特性

三、应用场景

四、数据的同步方式

五、rsync传输模式

六、rsync应用

七、rsync 命令

1. 格式

 1.1 作为远程命令

 1. 2 作为rsync服务

2. 选项

3. 配置文件

 3.1  全局配置

           3.2   模块配置

4. 守护进程传输

4.1 配置

4.2 创建用户

4.3 创建认证用户的密码

4.4 准备模块目录

4.5 重启服务

4.6 客户端远程传输

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

八、 rsync+inotfy实时同步

1. 服务器端

2.开发客户端

2.1 安装inotify工具

2.2  配置内核参数

2.3 命令

2.4 编写脚本

2.5 赋予执行权限

2.6  写入文件

总结



前言

今天学习的是rsync ,也是不用安装,直接用的服务,内容比较简单,我们一起来看看今天的内容吧!


提示:以下是本篇文章正文内容,下面案例可供参考

一、概述

    rsync是linux 下一个远程数据同步工具
    他可通过LAN/WAN快速同步多台主机间的文件和目录,并适当利用rsync 算法减少数据的传输
    会对比两个文件的不同部分,传输差异部分,因此传输速度相当快
    rsync可拷贝、显示目录属性,以及拷贝文件,并选择性的压缩及递归拷贝

二、特性

快速
        第一次传输全部,下一次传输差异
        rsync在传输过程中可以实行压缩和解压缩,使用更少的带宽
安全
        可以使用scp、ssh等方式传输
        直接通过socket连接
        支持匿名传输、方便进行网站镜像

三、应用场景

    增量同步
    备份迁移

四、数据的同步方式

    数据备份:拉取(下载)
        pull
    数据恢复:推送(上传)
        push

五、rsync传输模式

    本地传输
        本地同步数据,类似于cp
    远程传输
        远程同步数据,类似于scp
    守护进程
        通过模块化的方式实现批量传输

六、rsync应用

 安装
        yum -y install rsync
            如果已经安装,直接启动

启动
        systemctl start rsyncd
监听端口号
        TCP/873

七、rsync 命令

1. 格式

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

 1.1 作为远程命令

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


 1. 2 作为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
        在传输文件时进行压缩

举例
    本地
        rsync  -avz  abc/  /opt
        rsync  -avz  /abc  /opt
    远程
        rsync -avz root@192.168.2.7:/etc/hostname  /root/
        rsync -avz  /root/hostname root@192.168.2.7:/etc/hostname 

3. 配置文件

/etc/rsyncd.conf


 3.1  全局配置

address 独立运行时,用于指定服务器运行的 IP 地址,默认本地所有IP
port指定 rsync 守护进程监听的端口号,默认 873
 pid filersync 的守护进程将其 PID 写入指定的文件
log file  指定 rsync 守护进程的日志文件,而不将日志发送给 syslog
syslog facility指定 rsync 发送日志消息给 syslog 时的消息级别
socket options指定自定义 TCP 选项
 lockfile指定rsync的锁文件存放路径
 timeout 超时时间

        
  3.2   模块配置

 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指定密码文件

4. 守护进程传输

4.1 配置

    uid=rsync
    gid=rsync
    fake super=yes     # 用于允许非root用户,在备份目录创建文件
    list=false              # 默认true,允许查看本机有哪些模块
    auth users=rsync_backup  # 用于指定认证用户
    secrets file=/etc/rsync.passwd  # 指定认证用户密码
    read only = false
    max connections=4                 # 允许最大连接数
    read only=false                       # 默认yes,模块目录只读权限
    ignore errors                          # 屏蔽错误报错
    timeout=900                          # 指定rsync传输超时时间
    [backup]
    path=/backup

 

 4.2 创建用户

   useradd rsync -s /sbin/nologin -M          
     

 4.3 创建认证用户的密码


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

  4.4 准备模块目录

    mkdir /backup
    chown rsync.rsync /backup   

4.5 重启服务

systemctl restart rsyncd

4.6 客户端远程传输

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

服务端查看

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

   vim /etc/rsync.passwd
        123456
    chmod   600 /etc/rsync.passwd
    rsync -avz /etc/hosts rsync_backup@192.168.2.62::backup --password-file /etc/rsync.passwd

 练习
    1、使用认证用户为jx_名字缩写,认证密码为班级编号
    2、模块名称为juexing
    3、客户端创建文件user.txt,内容为所有的用户信息
    4、自行修改文件内容,在服务器上实现同步

服务端 

客户端

 服务端查看

八、 rsync+inotfy实时同步

1. 服务器端

  安装网站服务,启动,但是不写首页文件
    修改主配置文件
        uid = root
        gid = root
        [wwwroot]
    path = /var/www/html
    comment = backup export area
    read only = false
    hosts allow = 192.168.1.0/24

 

2.开发客户端

2.1 安装inotify工具

        inotify-tools
        tar xf  inotify-tools-3.14.tar.gz
        ./configure && make && make install

2.2  配置内核参数

vim /etc/sysctl.conf
        fs.inotify.max_user_instances = 1024
        fs.inotify.max_queued_events = 16384
        fs.inotify.max_user_watches=1048576
        sysctl -P

2.3 命令

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

客户端上传

 服务端查看


  2.4 编写脚本 

 vim /opt/inotify_rsync.sh
        #!/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.115.130::wwwroot"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
$RSYNC_CMD 
done

服务端

2.5 赋予执行权限

 chmod +x inotify_rsync.sh

2.6  写入文件

   vim /etc/rc.local
            /root/inotify_rsync.sh

客户端 

 服务端


总结

以上就是今天要讲的内容,本文仅仅简单介绍了rsync 的概念、用途及使用方法,需要我们动手操作起来,所以,要好好联系哦!

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

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

相关文章

分布式定时任务组件:XXL-JOB

一、GitHub源码地址 https://github.com/xuxueli/xxl-job 二、部署文档 参考:https://blog.csdn.net/qq798867485/article/details/131415408 三、初始化数据库SQL 1、xxl_job_user XxlJob-用户管理 2、xxl_job_group XxlJob-执行器管理 3、xxl…

〖码银送书第三期〗《Python机器学习:基于PyTorch和Scikit-Learn》

前言 近年来,机器学习方法凭借其理解海量数据和自主决策的能力,已在医疗保健、 机器人、生物学、物理学、大众消费和互联网服务等行业得到了广泛的应用。自从AlexNet模型在2012年ImageNet大赛被提出以来,机器学习和深度学习迅猛发展&#xf…

性能测试:Jmeter压测过程中的短信验证码读取

目录 问题背景 解决思路 实现方法 1. 建立JDBC连接 2. 使用JDBC请求获取验证码 3. 使用正则将验证码提取并使用 总结: 问题背景 现如今国内的大部分软件或者网站应用,普遍流行使用短信业务,比如登录、注册以及特定的业务通知等。 对…

基于区块链技术的元宇宙游戏将成为时代浪潮的弄潮儿

区块链技术作为互联网新兴技术逐渐走进公众视野,其中心化、分布式、公开透明、不可篡改等技术特性使其可以在各个领域大展拳脚。区块链技术在金融、公益、文化、物流、农业等领域带来了全新的思维视角、全新的场景与全新的解决方案,无疑是移动互联网之后…

【Matlab】智能优化算法_麻雀搜索算法SSA

【Matlab】智能优化算法_麻雀搜索算法SSA 1.背景介绍2.数学模型3.文件结构4.伪代码5.详细代码及注释5.1 Get_Functions_details.m5.2 main.m5.3 SSA.m 6.运行结果7.参考文献 1.背景介绍 麻雀通常是群居的鸟类,有很多种类。它们分布在世界的大部分地区,喜…

GSV6201替代方案|CS5466设计资料|CS5466原理图|typec转HDMI_8k方案芯片

GSV6201是一款高性能、低功耗、高性能的,USB Type-C备用模式显示端口1.4至HDMI 2.1转换器。通过集成增强型微控制器,GSV6201创造了一个经济高效的解决方案提供了上市时间优势。显示端口接收机支持高达32.4Gbps(HBR3,4通道&#xf…

springboot整合feign实现RPC调用,并通过Hystrix实现服务降级

目录 一、服务提供者 二、服务消费者 三、测试效果 四、开启Hystrix实现服务降级 feign/openfeign和dubbo是常用的微服务RPC框架,由于feigin内部已经集成ribbon,自带了负载均衡的功能,当有多个同名的服务注册到注册中心时,会根…

ES系列--打分机制

一、文档打分机制 当你通过关键字搜索相关文档时,可能会出现多个文档,这些文档的顺序是通过一个max_score属性的大小从高到低顺序展现出来的,max_score属性就是我们所说的评分。而这个评分是通过一个文档打分机制计算出来的。 二、打分原理 …

MySQL操作库

MySQL操作库 一.创建数据库1. 创建数据库的方式2. 创建数据库时的编码问题3. 指定编码创建数据库4. 验证校验规则对数据库的影响 二.数据库与文件系统的关系三.操纵数据库1. 查看数据库2. 删除数据库3. 修改数据库 四.数据库的备份和恢复1.数据库的备份2.数据库的恢复 五.查看连…

计算机vcruntime140.dll丢失的解决方法,重新安装教程

vcruntime140.dll是Microsoft Visual C Redistributable文件中的一个动态链接库(DLL)。这个文件是由Microsoft开发的,用于支持C编程语言的运行环境。vcruntime140.dll是Windows系统非常重要的文件,通常会被一些应用程序或游戏所需…

Docker 安装 Nginx,并实现负载均衡

1、获取 nginx 的镜像 # 默认是latest版本docker pull nginx 2、运行 nginx 容器 docker run --name nginx-80 -p 80:80 --rm -d nginx# --name nginx-80 设定容器的名称# -p 80:80 端口进行映射,将本地的80端口映射到容器内部的80端口# --rm 表示容器退出后直接…

python_day11_practice

将文本数据插入数据库 两文本文件为day10面向对象练习案例 将data_define.py文件复制过来(导入失败,疑惑) 新建数据库,建表orders -- CREATE DATABASE py_sql charset utf8;use py_sql;create table orders(order_date date,…