Rsync

Rsync 介绍

rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。 rsync使用所谓的“rsync算法”来使本地和远程两个主机之间的文件达到同步,这个算法只传送两个文件的不同部分,而不是每次都整份传送,因此速度相当快。

Rsync安装配置

  • 查看rsync包是否安装 rpm -qa rsync
  • 修改rsync默认配置文件 vim /etc/rsyncd.conf

      # /etc/rsyncd: configuration file for rsync daemon mode
        
      # See rsyncd.conf man page for more options.
        
      # configuration example:
        
      uid = root       执行运行用户
      gid = root 		 执行运行用户组
      use chroot = no  不启用chroot,传输文件之前不会cd到文件系统目录当中
      max connections = 4		客户端最大连接数
      # pid file = /var/run/rsyncd.pid
      lock file = /var/run/rsyncd.lock   指定max connections参数的锁文件,默认值即为/var/run/rsyncd.lock
      log file = /var/log/rsyncd.log	   日志文件
      exclude = lost+found/		指定服务端的运行模式
      transfer logging = yes      传输文件时是否显示日志
      timeout = 900				超时时间
      ignore nonreadable = yes    指定服务端忽略用户没有权限的文件
      dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2   指定后缀为这些名称的文件不经过压缩,直接传送
        
      # [ftp]
      #path = /home/ftp
      #comment = ftp export area
      [wms]						块名称  同步时 基于这个名称
      path=/opt/local/wms/		同步的真实目录
      comment=wms					模块描述
      ignore errors				忽略错误
      read only=yes				设定是否允许用户上传文件,若为yes,则任何上传都会失败,若为no则允许上传
      write only=no				设定是否允许用户下载文件,若为yes,则任何下载都会失败,若为no则允许下载
      list=no						设定模块是否允许列出
      auth user=rsyncuser			授权用户
      secrets file=/etc/rsyncd.passwd		指定秘钥文件
      hosts allow=*						指定允许的主机列表
      [patch]		
      path=/opt/local/patch/
      comment=patch
      ignore errors
      read only=yes
      write only=no
      list=no
      auth user=rsyncuser
      secrets file=/etc/rsyncd.passwd
      hosts allow=*
    
  • 重新启动rsyncd服务systmectl restart rsyncd

Rsync工作模式

  1. 本地文件系统同步 rsync [OPTION...] SRC... [DEST] rsync /etc/hosts /tmp
  2. 本地主机使用远程shell和远程主机通信
    Pull: rsync [OPTION...] [USER@]HOST:SRC... [DEST]
Push: rsync [OPTION...] SRC... [USER@]HOST:DEST
`rsync -r /etc 192.168.100.155:/tmp`  主动推送模式 将本地文件推送到远程 3. 本地主机连接Rsync服务器

	 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 -avzP root@192.168.100.154::patch /tmp #将服务端patch模块对应的目录同步到本地的/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:要求删除源端已经成功传输的文件。


**常用参数组合 “-avz”**