• rsync-基本介绍


    使用rsync目的是能够将本地主机与远程主机上的文件同步

    rsync组成

    1. 检查模块:默认使用"quick check"算法快速检查源文件和目标文件的大小mtime是否一致;也可以自定义选项规定
    2. 同步模块:确定同步后,在同步之前规定需要做哪些工作,可以通过自定义选项规定
      • 涉及到的问题
        1. 同一文件:源没有,而目标有,是否删除
        2. 文件时间:源文件与目标文件时间戳不同,是否更新
        3. 软连接:拷贝源链接本身,还是拷贝软连接指向的源文件
        4. 目标文件已存在时,是否先对其做备份

    rsync同步方式

    1. 本地不同路径下文件的同步
    2. 本地推到远程 push
    3. 远程拉取到本地 pull

    rsync同步基准

    1. 以本地文件为基准:将本地文件作为源文件推到目标主机上
    2. 以目标主机文件为基准:将目标主机上的文件拉取到本地主机上

    rsync使用方法

    • 本地不同路径下文件的同步
    Local: rsync [options...] src... [dest]
    
    示例:
    ]# rsync /etc/fstab /tmp #将本地fstab文件拷贝到/tmp目录下
    ]# rsync -a /etc /tmp #将本地etc目录拷贝到/tmp目录下(在tmp目录下创建etc目录)
    ]# rsync -a /etc/ /tmp #将本地etc目录下的所有文件拷贝到/tmp目录下(不会创建etc目录)
    
    • 使用远程shell和远程主机通信
    Access via reomte shell
        pull: rsync [option...] [user@]host:src... [dest]
        push: rsync [option..] src... [user@]host:dest
    
    示例:
    ]# rsync 192.168.153.131:/etc/fstab /tmp #将远程主机fstab文件拉取到本地/tmp目录下
    ]# rsync -a /etc 192.168.153.131:/tmp #将本地etc目录推送到远程主机/tmp目录下(在tmp目录下创建etc目录)
    
    • 通过套接字连接远程主机上的rsync daemon
    Access via rsync daemon:
        pull: 
                rsync [option...] [user@]host::src... [dest]
                rsync [option...] rsync://[user@]host[:port]/src... [dest]
        push: 
                rsync [option...] src... [user@]host::dest
                rsync [option...] src... rsync://[user@]host[:port]/dest
    示例:
    ]# rsync 192.168.153.131::/etc/fstab /tmp #将远程主机fstab文件拉取到本地/tmp目录下
    ]# rsync -avz rsync://192.168.153.131:/etc /tmp #将远程主机fstab文件拉取到本地/tmp目录下(在tmp目录下创建etc目录)
    ]# rsync -avz /etc/ 192.168.153.131::/tmp #将本地etc目录下的所有文件推送到远程主机/tmp目录下(不会创建etc目录)
    ]# rsync -avz /etc rsync://192.168.153.131:/tmp #将本地etc目录下的所有文件推送到远程主机/tmp目录下(在tmp目录下创建etc目录)
    

    特殊示例说明

    1. 不论路径多长,均在目标主机下生成该子目录
    ]# rsync -R -r /etc/cron.d /tmp #结果是/tmp/etc/cron.d
    
    1. 不论路径多长,指定生成路径中的部分目录
    ]# rsync -R -r  /etc/./sysconfig/network-scripts /tmp #结果是/tmp/sysconfig/network-scripts
    ]# tree /tmp
    
    1. 对目标主机已存在的文件做备份,备份文件后带有后缀"~"
    ]# rsync -R -r --backup /etc/./sysconfig/network-scripts /tmp
    
    1. 对目标主机已存在的文件做备份,并指定备份文件保存路径,默认不会带有后缀"~"
    ]# rsync -R -r --backup --backup-dir=/tmp/log_bak /etc/./sysconfig/network-scripts /tmp
    

    rsync常用参数

    -v:显示rsync过程中详细信息。可以使用"-vvvv"获取更详细信息。
    -P:显示文件传输的进度信息。(实际上"-P"="--partial --progress",其中的"--progress"才是显示进度信息的)。
    -n --dry-run  :仅测试传输,而不实际传输。常和"-vvvv"配合使用来查看rsync是如何工作的。
    -a --archive  :归档模式,表示递归传输并保持文件属性。等同于"-rtopgDl"。
    -r --recursive:递归到目录中去。
    -t --times:保持mtime属性。强烈建议任何时候都加上"-t",否则目标文件mtime会设置为系统时间,导致下次更新
              :检查出mtime不同从而导致增量传输无效。
    -o --owner:保持owner属性(属主)。
    -g --group:保持group属性(属组)。
    -p --perms:保持perms属性(权限,不包括特殊权限)。
    -D        :是"--device --specials"选项的组合,即也拷贝设备文件和特殊文件。
    -l --links:如果文件是软链接文件,则拷贝软链接本身而非软链接所指向的对象。
    -z        :传输时进行压缩提高效率。
    -R --relative:使用相对路径。意味着将命令行中指定的全路径而非路径最尾部的文件名发送给服务端,包括它们的属性。
    --size-only :默认算法是检查文件大小和mtime不同的文件,使用此选项将只检查文件大小。
    -u --update :仅在源mtime比目标已存在文件的mtime新时才拷贝。注意,该选项是接收端判断的,不会影响删除行为。
    -d --dirs   :以不递归的方式拷贝目录本身。默认递归时,如果源为"dir1/file1",则不会拷贝dir1目录,使用该选项将拷贝dir1但不拷贝file1。
    --max-size  :限制rsync传输的最大文件大小。可以使用单位后缀,还可以是一个小数值(例如:"--max-size=1.5m")
    --min-size  :限制rsync传输的最小文件大小。这可以用于禁止传输小文件或那些垃圾文件。
    --exclude   :指定排除规则来排除不需要传输的文件。
    --delete    :以SRC为主,对DEST进行同步。多则删之,少则补之。注意"--delete"是在接收端执行的,所以它是在
                :exclude/include规则生效之后才执行的。
    -b --backup :对目标上已存在的文件做一个备份,备份的文件名后默认使用"~"做后缀。
    --backup-dir:指定备份文件的保存路径。不指定时默认和待备份文件保存在同一目录下。
    -e          :指定所要使用的远程shell程序,默认为ssh。
    --port      :连接daemon时使用的端口号,默认为873端口。
    --password-file:daemon模式时的密码文件,可以从中读取密码实现非交互式。注意,这不是远程shell认证的密码,而是rsync模块认证的密码。
    -W --whole-file:rsync将不再使用增量传输,而是全量传输。在网络带宽高于磁盘带宽时,该选项比增量传输更高效。
    --existing  :要求只更新目标端已存在的文件,目标端还不存在的文件不传输。注意,使用相对路径时如果上层目录不存在也不会传输。
    --ignore-existing:要求只更新目标端不存在的文件。和"--existing"结合使用有特殊功能,见下文示例。
    --remove-source-files:要求删除源端已经成功传输的文件。
    
  • 相关阅读:
    Linux Bash
    grep 及正则表达式
    Linux 文件系统
    Linux 操作系统基础
    常见的磁盘I/O和网络I/O优化技巧
    NIO的工作方式
    网络I/O 工作机制
    spring Boot环境下dubbo+zookeeper的一个基础讲解与示例
    深入分析Java I/O 工作机制
    CDN工作机制和负载均衡
  • 原文地址:https://www.cnblogs.com/wanwz/p/12801557.html
Copyright © 2020-2023  润新知