免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3749 | 回复: 8
打印 上一主题 下一主题

求助:那位能够提供rsync的详细参数说明啊? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-07-28 11:38 |只看该作者 |倒序浏览
需要rsync的详细参数说明,我找不到中文版的,大家帮帮忙

论坛徽章:
1
寅虎
日期:2013-09-29 23:15:15
2 [报告]
发表于 2004-07-28 14:28 |只看该作者

求助:那位能够提供rsync的详细参数说明啊?

给你转一篇

  1. 用rsync实现网站镜像和备份

  2. 作者:ideal <ideal@linuxaid.com.cn>;

  3. 简介
  4. 对于选择Linux 作为应用平台的的中小型企业或网站来说,往往面临如何实现数据远程备份或者网站镜象的问题,虽然有商业化的备份和镜象产品可供选择,但这些产品的价格往往过于昂贵。因此如何利用自由软件高效实现远程备份和网站镜象就成为一个值得讨论的话题。

  5. 通过网络进行远程数据备份或者网站镜象的最简单的方法就是使用wget,但是这种方式每次都需要将所有数据都重新在网络上传输一遍,而不考虑哪些文件是经过更新的,因此效率非常低下。尤其在需要备份的数据量很大的时候,往往需要花费数个小时来在网络上进行数据传输。

  6. 因此这里就介绍一种高效的网络远程备份和镜象工具-rsync,它可以满足绝大多数要求不是特别严格的备份需求。

  7. rsync是类unix系统下的数据镜像备份工具,从软件的命名上就可以看出来了——remote sync。它的特性如下:

  8. 可以镜像保存整个目录树和文件系统。
  9. 可以很容易做到保持原来文件的权限、时间、软硬链接等等。
  10. 无须特殊权限即可安装。
  11. 优化的流程,文件传输效率高。
  12. 可以使用rcp、ssh等方式来传输文件,当然也可以通过直接的socket连接。
  13. 支持匿名传输,以方便进行网站镜象。
  14. 软件下载
  15. rysnc的主页地址为:

  16. http://rsync.samba.org/

  17. 目前最新版本为2.4.6。可以选择从原始网站下载:http://rsync.samba.org/ftp/rsync/。也可以选择从本站下载:rsync 2.4.6。

  18. 编译安装
  19. rsync的编译安装非常简单,只需要以下简单的几步:

  20. [root@www rsync-2.4.6]# ./configure
  21. [root@www rsync-2.4.6]# make
  22. [root@www rsync-2.4.6]# make install

  23. 但是需要注意的是必须在服务器A和B上都安装rsync,其中A服务器上是以服务器模式运行rsync,而B上则以客户端方式运行rsync。这样在web服务器A上运行rsync守护进程,在B上定时运行客户程序来备份web服务器A上需要备份的内容。

  24. rsync服务器
  25. 1、rsync服务器的启动

  26. 在web服务器A上需要以守护进程方式来启动rsync服务器,只需要运行:

  27. [root@www rsync-2.4.6]# /usr/local/bin/rsync --daemon

  28. 即可启动。rsync默认服务端口为873,服务器在该端口接收客户的匿名或者认证方式的备份请求。

  29. 如果要在启动时把服务起来,有几种不同的方法,比如:

  30. a、加入inetd.conf

  31. 编辑/etc/services,加入rsync 873/tcp,指定rsync的服务端口是873。编加/etc/inetd.conf,加入rsync stream tcp nowait root /bin/rsync rsync --daemon

  32. 注:对于xinetd,设置方法类似。

  33. b、加入rc.local

  34. 编辑/etc/rc.d/rc.local,在最后添加:

  35. /usr/local/bin/rsync --daemon

  36. 2、rsync的配置

  37. 对于rsync服务器来说,最重要和复杂的就是它的配置了。rsync服务器的配置文件为/etc/rsyncd.conf,其控制认证、访问、日志记录等等。

  38. 该文件是由一个或多个模块结构组成。一个模块定义以方括弧中的模块名开始,直到下一个模块定义开始或者文件结束,模块中包含格式为name = value的参数定义。每个模块其实就对应需要备份的一个目录树,比方说在我们的实例环境中,有三个目录树需要备份:/www/、 /home/web_user1/和/home/web_user2/,那么就需要在配置文件中定义三个模块,分别对应三个目录树。

  39. 配置文件是行为单位的,也就是每个新行都表示一个新的注释、模块定义或者参数赋值。以#开始的行表示注释,以"\"结束的行表示下面一行是该行的继续。参数赋值中等号后可能是一个大小写不敏感的字符串、一个以trure/false表示的布尔值。

  40. 全局参数

  41. 在文件中[modlue]之前的所有参数都是全局参数,当然也可以在全局参数部分定义模块参数,这时候该参数的值就是所有模块的默认值。

  42. motd file

  43. "motd file"参数用来指定一个消息文件,当客户连接服务器时该文件的内容显示给客户,默认是没有motd文件的。

  44. log file

  45. "log file"指定rsync的日志文件,而不将日志发送给syslog。

  46. pid file

  47. 指定rsync的pid文件。

  48. syslog facility

  49. 指定rsync发送日志消息给syslog时的消息级别,常见的消息级别是:uth, authpriv, cron, daemon, ftp, kern, lpr, mail, news, security, sys-log, user, uucp, local0, local1, local2, local3,local4, local5, local6和local7。默认值是daemon。

  50. 模块参数

  51. 在全局参数之后就需要定义一个或多个模块了,模块中可以定义以下参数:

  52. comment

  53. 给模块指定一个描述,该描述连同模块名在客户连接得到模块列表时显示给客户。默认没有描述定义。

  54. path

  55. 指定该模块的供备份的目录树路径,该参数是必须指定的。

  56. use chroot

  57. 如果"use chroot"指定为true,那么rsync在传输文件以前首先chroot到path参数所指定的目录下。这样做的原因是实现额外的安全防护,但是缺点是需要以roots权限,并且不能备份指向外部的符号连接所指向的目录文件。默认情况下chroot值为true。

  58. max connections

  59. 指定该模块的最大并发连接数量以保护服务器,超过限制的连接请求将被告知随后再试。默认值是0,也就是没有限制。

  60. lock file

  61. 指定支持max connections参数的锁文件,默认值是/var/run/rsyncd.lock。

  62. read only

  63. 该选项设定是否允许客户上载文件。如果为true那么任何上载请求都会失败,如果为false并且服务器目录读写权限允许那么上载是允许的。默认值为true。

  64. list

  65. 该选项设定当客户请求可以使用的模块列表时,该模块是否应该被列出。如果设置该选项为false,可以创建隐藏的模块。默认值是true。

  66. uid

  67. 该选项指定当该模块传输文件时守护进程应该具有的uid,配合gid选项使用可以确定哪些可以访问怎么样的文件权限,默认值是"nobody"。

  68. gid

  69. 该选项指定当该模块传输文件时守护进程应该具有的gid。默认值为"nobody"。

  70. exlude

  71. 用来指定多个由空格隔开的多个模式列表,并将其添加到exclude列表中。这等同于在客户端命令中使用--exclude来指定模式,不过配置文件中指定的exlude模式不会传递给客户端,而仅仅应用于服务器。一个模块只能指定一个exlude选项,但是可以在模式前面使用"-"和"+"来指定是 exclude还是include。

  72. 但是需要注意的一点是该选项有一定的安全性问题,客户很有可能绕过exlude列表,如果希望确保特定的文件不能被访问,那就最好结合uid/gid选项一起使用。

  73. exlude from

  74. 指定一个包含exclude模式的定义的文件名,服务器从该文件中读取exlude列表定义。

  75. include

  76. 用来指定多个由空格隔开的多个rsync并应该exlude的模式列表。这等同于在客户端命令中使用--include来指定模式,结合 include和 exlude可以定义复杂的exlude/include规则。一个模块只能指定一个include选项,但是可以在模式前面使用"-"和"+"来指定是 exclude还是include。

  77. include from

  78. 指定一个包含include模式的定义的文件名,服务器从该文件中读取include列表定义。

  79. auth users

  80. 该选项指定由空格或逗号分隔的用户名列表,只有这些用户才允许连接该模块。这里的用户和系统用户没有任何关系。如果"auth users"被设置,那么客户端发出对该模块的连接请求以后会被rsync请求challenged进行验证身份这里使用的 challenge/response认证协议。用户的名和密码以明文方式存放在"secrets file"选项指定的文件中。默认情况下无需密码就可以连接模块(也就是匿名方式)。

  81. secrets file

  82. 该选项指定一个包含定义用户名:密码对的文件。只有在"auth users"被定义时,该文件才有作用。文件每行包含一个username:passwd对。一般来说密码最好不要超过8个字符。没有默认的 secures file名,需要限式指定一个。(例如:/etc/rsyncd.secrets)

  83. strict modes

  84. 该选项指定是否监测密码文件的权限,如果该选项值为true那么密码文件只能被rsync服务器运行身份的用户访问,其他任何用户不可以访问该文件。默认值为true。

  85. hosts allow

  86. 该选项指定哪些IP的客户允许连接该模块。客户模式定义可以是以下形式:

  87. o xxx.xxx.xxx.xxx,客户主机只有完全匹配该IP才允许访问。例如:192.167.0.1

  88. o a.b.c.d/n,属于该网络的客户都允许连接该模块。例如:192.168.0.0/24

  89. o a.b.c.d/e.f.g.h,属于该网络的客户都允许连接该模块。例如:192.168.0.0/255.255.255.0

  90. o 一个主机名,客户主机只有拥有该主机名才允许访问,例如:backup.linuxaid.com.cn。


  91. o *.linuxaid.com.cn,所有属于该域的主机都允许。

  92. 默认是允许所有主机连接。

  93. hosts deny

  94. 指定不允许连接rsync服务器的机器,可以使用hosts allow的定义方式来进行定义。默认是没有hosts deny定义。

  95. ignore errors

  96. 指定rsyncd在判断是否运行传输时的删除操作时忽略server上的IP错误,一般来说rsync在出现IO错误时将将跳过--delete操作,以防止因为暂时的资源不足或其它IO错误导致的严重问题。

  97. ignore nonreadable

  98. 指定rysnc服务器完全忽略那些用户没有访问权限的文件。这对于在需要备份的目录中有些文件是不应该被备份者得到的情况是有意义的。

  99. transfer logging

  100. 使rsync服务器使用ftp格式的文件来记录下载和上载操作在自己单独的日志中。

  101. log format

  102. 通过该选项用户在使用transfer logging可以自己定制日志文件的字段。其格式是一个包含格式定义符的字符串,可以使用的格式定义符如下所示:

  103. o %h 远程主机名

  104. o %a 远程IP地址

  105. o %l 文件长度字符数

  106. o %p 该次rsync会话的进程id

  107. o %o 操作类型:"send"或"recv"

  108. o %f 文件名

  109. o %P 模块路径

  110. o %m 模块名

  111. o %t 当前时间

  112. o %u 认证的用户名(匿名时是null)

  113. o %b 实际传输的字节数

  114. o %c 当发送文件时,该字段记录该文件的校验码

  115. 默认log格式为:"%o %h [%a] %m (%u) %f %l",一般来说,在每行的头上会添加"%t [%p] "。在源代码中同时发布有一个叫rsyncstats的perl脚本程序来统计这种格式的日志文件。

  116. timeout

  117. 通过该选项可以覆盖客户指定的IP超时时间。通过该选项可以确保rsync服务器不会永远等待一个崩溃的客户。超时单位为秒钟,0表示没有超时定义,这也是默认值。对于匿名rsync服务器来说,一个理想的数字是600。

  118. refuse options

  119. 通过该选项可以定义一些不允许客户对该模块使用的命令参数列表。这里必须使用命令全名,而不能是简称。但发生拒绝某个命令的情况时服务器将报告错误信息然后退出。如果要防止使用压缩,应该是:"dont compress = *"。

  120. dont compress

  121. 用来指定那些不进行压缩处理再传输的文件,默认值是

  122. *.gz *.tgz *.zip *.z *.rpm *.deb *.iso *.bz2 *.tbz

  123. rsync客户命令
  124. 在对rsync服务器配置结束以后,下一步就需要在客户端发出rsync命令来实现将服务器端的文件备份到客户端来。rsync是一个功能非常强大的工具,其命令也有很多功能特色选项,我们下面就对它的选项一一进行分析说明。

  125. 首先,rsync的命令格式可以为:

  126. rsync [OPTION]... SRC [SRC]... [USER@]HOST:DEST

  127. rsync [OPTION]... [USER@]HOST:SRC DEST

  128. rsync [OPTION]... SRC [SRC]... DEST

  129. rsync [OPTION]... [USER@]HOST::SRC [DEST]

  130. rsync [OPTION]... SRC [SRC]... [USER@]HOST::DEST

  131. rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]
  132. rsync有六种不同的工作模式:

  133. 拷贝本地文件;当SRC和DES路径信息都不包含有单个冒号":"分隔符时就启动这种工作模式。

  134. 使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。当DST路径地址包含单个冒号":"分隔符时启动该模式。

  135. 使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。当SRC地址路径包含单个冒号":"分隔符时启动该模式。

  136. 从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含"::"分隔符时启动该模式。

  137. 从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含"::"分隔符时启动该模式。

  138. 列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。
  139. 1、用法

  140. 在使用rsync传输文件时,需要指定一个源和一个目的,其中一个可能是远程机器的资源信息。例如:

  141. rsync *.c foo:src/

  142. 表示将传输当前目录下所有以.c结尾的文件到机器foo的src目录下。如果任何文件已经存在于远程系统,则会调用远程更新协议来实现仅仅传输那些更新过的文件。

  143. rsync -avz foo:src/bar /data/tmp

  144. 该命令则递归地传输机器foo上的src/bar目录下的所有内容到本地/data/tmp/bar目录中。文件以归档模式进行传输,以确保符号链结、属性、权限、属主等信息在传输中都被保存。此外,可以使用压缩技术来加快数据传输:

  145. rsync -avz foo:src/bar/ /data/tmp

  146. 路径信息以"/"结尾时表示拷贝该目录,而不以"/"结尾表示拷贝该目录。当配合使用--delete选项时这两种情况的区别将会表现出来。

  147. 也可以以本地模式来使用rsync,如果SRC和DST路径中都没有任何":"符号则表示该命令运行在本地模式,等同于cp命令。

  148. rsync somehost.mydomain.com::

  149. 这种模式则将会列出somehost.mydomain.com.可以访问的所有模块信息。

  150. 选项说明

  151. -v, --verbose 详细模式输出
  152. -q, --quiet 精简输出模式
  153. -c, --checksum 打开校验开关,强制对文件传输进行校验
  154. -a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
  155. -r, --recursive 对子目录以递归模式处理
  156. -R, --relative 使用相对路径信息

  157. rsync foo/bar/foo.c remote:/tmp/

  158. 则在/tmp目录下创建foo.c文件,而如果使用-R参数:

  159. rsync -R foo/bar/foo.c remote:/tmp/

  160. 则会创建文件/tmp/foo/bar/foo.c,也就是会保持完全路径信息。

  161. -b, --backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用--suffix选项来指定不同的备份文件前缀。
  162. --backup-dir 将备份文件(如~filename)存放在在目录下。
  163. -suffix=SUFFIX 定义备份文件前缀
  164. -u, --update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)
  165. -l, --links 保留软链结
  166. -L, --copy-links 想对待常规文件一样处理软链结
  167. --copy-unsafe-links 仅仅拷贝指向SRC路径目录树以外的链结
  168. --safe-links 忽略指向SRC路径目录树以外的链结
  169. -H, --hard-links 保留硬链结
  170. -p, --perms 保持文件权限
  171. -o, --owner 保持文件属主信息
  172. -g, --group 保持文件属组信息
  173. -D, --devices 保持设备文件信息
  174. -t, --times 保持文件时间信息
  175. -S, --sparse 对稀疏文件进行特殊处理以节省DST的空间
  176. -n, --dry-run现实哪些文件将被传输
  177. -W, --whole-file 拷贝文件,不进行增量检测
  178. -x, --one-file-system 不要跨越文件系统边界
  179. -B, --block-size=SIZE 检验算法使用的块尺寸,默认是700字节
  180. -e, --rsh=COMMAND 指定替代rsh的shell程序
  181. --rsync-path=PATH 指定远程服务器上的rsync命令所在路径信息
  182. -C, --cvs-exclude 使用和CVS一样的方法自动忽略文件,用来排除那些不希望传输的文件
  183. --existing 仅仅更新那些已经存在于DST的文件,而不备份那些新创建的文件
  184. --delete 删除那些DST中SRC没有的文件
  185. --delete-excluded 同样删除接收端那些被该选项指定排除的文件
  186. --delete-after 传输结束以后再删除
  187. --ignore-errors 及时出现IO错误也进行删除
  188. --max-delete=NUM 最多删除NUM个文件
  189. --partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输
  190. --force 强制删除目录,即使不为空
  191. --numeric-ids 不将数字的用户和组ID匹配为用户名和组名
  192. --timeout=TIME IP超时时间,单位为秒
  193. -I, --ignore-times 不跳过那些有同样的时间和长度的文件
  194. --size-only 当决定是否要备份文件时,仅仅察看文件大小而不考虑文件时间
  195. --modify-window=NUM 决定文件是否时间相同时使用的时间戳窗口,默认为0
  196. -T --temp-dir=DIR 在DIR中创建临时文件
  197. --compare-dest=DIR 同样比较DIR中的文件来决定是否需要备份
  198. -P 等同于 --partial
  199. --progress 显示备份过程
  200. -z, --compress 对备份的文件在传输时进行压缩处理
  201. --exclude=PATTERN 指定排除不需要传输的文件模式
  202. --include=PATTERN 指定不排除而需要传输的文件模式
  203. --exclude-from=FILE 排除FILE中指定模式的文件
  204. --include-from=FILE 不排除FILE指定模式匹配的文件
  205. --version 打印版本信息
  206. --address 绑定到特定的地址
  207. --config=FILE 指定其他的配置文件,不使用默认的rsyncd.conf文件
  208. --port=PORT 指定其他的rsync服务端口
  209. --blocking-io 对远程shell使用阻塞IO
  210. -stats 给出某些文件的传输状态
  211. --progress 在传输时现实传输过程
  212. --log-format=FORMAT 指定日志文件格式
  213. --password-file=FILE 从FILE中得到密码
  214. --bwlimit=KBPS 限制I/O带宽,KBytes per second
  215. -h, --help 显示帮助信息
  216. 实例分析
  217. 这里假设有两台服务器:A和B。其中A是主web服务器,具有域名www.linuxaid.com.cn(202.99.11.120),B服务器是备份机,其域名为backup.linuxaid.com.cn(202.99.11.121)。其中A的web内容存放在以下几个地方: /www/和 /home/web_user1/和/home/web_user2/。我们需要在备份机B上建立对这几个目录内容的备份。

  218. 服务器配置实例

  219. 那么在www.linuxaid.com.cn上创建rsyncd的配置文件/etc/rsyncd.conf,内容如下:

  220. uid = nobody
  221. gid = nobody
  222. use chroot = no
  223. max connections = 4
  224. pid file = /var/run/rsyncd.pid
  225. lock file = /var/run/rsync.lock
  226. log file = /var/log/rsyncd.log

  227. [www]
  228. path = /www/
  229. ignore errors
  230. read only = true
  231. list = false
  232. hosts allow = 202.99.11.121
  233. hosts deny = 0.0.0.0/32
  234. auth users = backup
  235. secrets file = /etc/backserver.pas

  236. [web_user1]
  237. path = /home/web_user1/
  238. ignore errors
  239. read only = true
  240. list = false
  241. hosts allow = 202.99.11.121
  242. hosts deny = 0.0.0.0/32
  243. uid = web_user1
  244. gid = web_user1
  245. auth users = backup
  246. secrets file = /etc/backserver.pas

  247. [web_user2]
  248. path = /home/web_user2/
  249. ignore errors
  250. read only = true
  251. list = false
  252. hosts allow = 202.99.11.121
  253. hosts deny = 0.0.0.0/32
  254. uid = web_user2
  255. gid = web_user2
  256. auth users = backup
  257. secrets file = /etc/backserver.pas

  258. 这里定义有四个三个模块,分别对应于三个需要备份的目录树。这里只允许202.99.11.121备份本机的数据,并且需要认证。三个模块授权的备份用户都为backup,并且用户信息保存在文件/etc/backserver.pas中,其内容如下:

  259. backup:bk_passwd

  260. 并且该文件只能是root用户可读写的,否则rsyncd启动时会出错。这些文件配置完毕以后,就需要在A服务器上启动rsyncd服务器:

  261. rsync --daemon

  262. 客户命令示例

  263. /usr/local/bin/rsync -vzrtopg --delete --exclude "logs/" --exclude "conf/ssl.*/" --progress backup@202.99.11.120::www /backup/www/ --password-file=/etc/rsync.pass

  264. 上面这个命令行中-vzrtopg里的v是verbose,z是压缩,r是recursive,topg都是保持文件原有属性如属主、时间的参数。-- progress是指显示出详细的进度情况,--delete是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。-- exclude "logs/" 表示不对/www/logs目录下的文件进行备份。--exclude "conf/ssl.*/"表示不对/www/conf/ssl.*/目录下的文件进行备份。

  265. backup@202.99.11.120::www 表示对该命令是对服务器202.99.11.120中的www模块进行备份,backup表示使用backup来对该模块进行备份。

  266. --password-file=/etc/rsync.pass来指定密码文件,这样就可以在脚本中使用而无需交互式地输入验证密码了,这里需要注意的是这份密码文件权限属性要设得只有root可读。

  267. 这里将备份的内容存放在备份机的/backup/www/目录下。

  268. [root@linuxaid /]# /usr/local/bin/rsync -vzrtopg --delete --exclude "logs/" --exclude "conf/ssl.*/" --progress backup@202.99.11.120::www /backup/www/ --password-file=/etc/rsync.pass
  269. receiving file list ... done
  270. ./
  271. 1
  272. 785 (100%)
  273. 1.py
  274. 4086 (100%)
  275. 2.py
  276. 10680 (100%)
  277. a
  278. 0 (100%)
  279. ip
  280. 3956 (100%)
  281. ./
  282. wrote 2900 bytes read 145499 bytes 576.34 bytes/sec
  283. total size is 2374927 speedup is 45.34

  284. 对其它两个模块操作的命令分别为:

  285. /usr/local/bin/rsync -vzrtopg --delete --progress backup@202.99.11.120::web_user1 /backup/web_user1/ --password-file=/etc/rsync.pass

  286. /usr/local/bin/rsync -vzrtopg --delete --progress backup@202.99.11.120::web_user2 /backup/web_user2/ --password-file=/etc/rsync.pass

  287. 可以将客户命令通过crontab -e命令来实现自动备份,如crontab -e:

  288.  

  289. 一些示例脚本
  290. 这里这些脚本都是rsync网站上的例子:

  291. 1、每隔七天将数据往中心服务器做增量备份

  292. #!/bin/sh

  293. # This script does personal backups to a rsync backup server. You will end up
  294. # with a 7 day rotating incremental backup. The incrementals will go
  295. # into subdirectories named after the day of the week, and the current
  296. # full backup goes into a directory called "current"
  297. # tridge@linuxcare.com

  298. # directory to backup
  299. BDIR=/home/$USER

  300. # excludes file - this contains a wildcard pattern per line of files to exclude
  301. EXCLUDES=$HOME/cron/excludes

  302. # the name of the backup machine
  303. BSERVER=owl

  304. # your password on the backup server
  305. export RSYNC_PASSWORD=XXXXXX


  306. ########################################################################

  307. BACKUPDIR=`date +%A`
  308. OPTS="--force --ignore-errors --delete-excluded --exclude-from=$EXCLUDES
  309. --delete --backup --backup-dir=/$BACKUPDIR -a"

  310. export PATH=$PATH:/bin:/usr/bin:/usr/local/bin

  311. # the following line clears the last weeks incremental directory
  312. [ -d $HOME/emptydir ] || mkdir $HOME/emptydir
  313. rsync --delete -a $HOME/emptydir/ $BSERVER::$USER/$BACKUPDIR/
  314. rmdir $HOME/emptydir

  315. # now the actual transfer
  316. rsync $OPTS $BDIR $BSERVER::$USER/current

  317. 2、备份至一个空闲的硬盘

  318. #!/bin/sh

  319. export PATH=/usr/local/bin:/usr/bin:/bin

  320. LIST="rootfs usr data data2"

  321. for d in $LIST; do
  322. mount /backup/$d
  323. rsync -ax --exclude fstab --delete /$d/ /backup/$d/
  324. umount /backup/$d
  325. done

  326. DAY=`date "+%A"`

  327. rsync -a --delete /usr/local/apache /data2/backups/$DAY
  328. rsync -a --delete /data/solid /data2/backups/$DAY

  329. 3、对vger.rutgers.edu的cvs树进行镜像

  330. #!/bin/bash

  331. cd /var/www/cvs/vger/
  332. PATH=/usr/local/bin:/usr/freeware/bin:/usr/bin:/bin

  333. RUN=`lps x | grep rsync | grep -v grep | wc -l`
  334. if [ "$RUN" -gt 0 ]; then
  335. echo already running
  336. exit 1
  337. fi

  338. rsync -az vger.rutgers.edu::cvs/CVSROOT/ChangeLog $HOME/ChangeLog

  339. sum1=`sum $HOME/ChangeLog`
  340. sum2=`sum /var/www/cvs/vger/CVSROOT/ChangeLog`

  341. if [ "$sum1" = "$sum2" ]; then
  342. echo nothing to do
  343. exit 0
  344. fi

  345. rsync -az --delete --force vger.rutgers.edu::cvs/ /var/www/cvs/vger/
  346. exit 0

  347. FAQ
  348. Q:如何通过ssh进行rsync,而且无须输入密码?
  349. A:可以通过以下几个步骤

  350. 1. 通过ssh-keygen在server A上建立SSH keys,不要指定密码,你会在~/.ssh下看到identity和identity.pub文件
  351. 2. 在server B上的home目录建立子目录.ssh
  352. 3. 将A的identity.pub拷贝到server B上
  353. 4. 将identity.pub加到~[user b]/.ssh/authorized_keys
  354. 5. 于是server A上的A用户,可通过下面命令以用户B ssh到server B上了
  355. e.g. ssh -l userB serverB
  356. 这样就使server A上的用户A就可以ssh以用户B的身份无需密码登陆到server B上了。

  357. Q:如何通过在不危害安全的情况下通过防火墙使用rsync?
  358. A:解答如下:

  359. 这通常有两种情况,一种是服务器在防火墙内,一种是服务器在防火墙外。无论哪种情况,通常还是使用ssh,这时最好新建一个备份用户,并且配置 sshd仅允许这个用户通过RSA认证方式进入。如果服务器在防火墙内,则最好限定客户端的IP地址,拒绝其它所有连接。如果客户机在防火墙内,则可以简单允许防火墙打开TCP端口22的ssh外发连接就ok了。

  360. Q:我能将更改过或者删除的文件也备份上来吗?
  361. A:当然可以:

  362. 你可以使用如:rsync -other -options -backupdir = ./backup-2000-2-13 ...这样的命令来实现。
  363. 这样如果源文件:/path/to/some/file.c改变了,那么旧的文件就会被移到./backup-2000-2-13/path/to/some/file.c,
  364. 这里这个目录需要自己手工建立起来

  365. Q:我需要在防火墙上开放哪些端口以适应rsync?
  366. A:视情况而定

  367. rsync可以直接通过873端口的tcp连接传文件,也可以通过22端口的ssh来进行文件传递,但你也可以通过下列命令改变它的端口:

  368. rsync --port 8730 otherhost::
  369. 或者
  370. rsync -e 'ssh -p 2002' otherhost:

  371. Q:我如何通过rsync只复制目录结构,忽略掉文件呢?
  372. A:rsync -av --include '*/' --exclude '*' source-dir dest-dir

  373. Q:为什么我总会出现"Read-only file system"的错误呢?
  374. A:看看是否忘了设"read only = no"了

  375. Q:为什么我会出现'@ERROR: invalid gid'的错误呢?
  376. A:rsync使用时默认是用uid=nobody;gid=nobody来运行的,如果你的系统不存在nobody组的话,就会出现这样的错误,可以试试gid = nogroup或者其它

  377. Q:绑定端口873失败是怎么回事?
  378. A:如果你不是以root权限运行这一守护进程的话,因为1024端口以下是特权端口,会出现这样的错误。你可以用--port参数来改变。

  379. Q:为什么我认证失败?
  380. A:从你的命令行看来:

  381. 你用的是:
  382. >; bash$ rsync -a 144.16.251.213::test test
  383. >; Password:
  384. >; @ERROR: auth failed on module test
  385. >;
  386. >; I dont understand this. Can somebody explain as to how to acomplish this.
  387. >; All suggestions are welcome.

  388. 应该是没有以你的用户名登陆导致的问题,试试rsync -a max@144.16.251.213::test test
复制代码

论坛徽章:
0
3 [报告]
发表于 2004-07-29 00:12 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
4 [报告]
发表于 2004-07-29 15:41 |只看该作者

求助:那位能够提供rsync的详细参数说明啊?

多谢。
主要是我们用rsync比较多,有大量的数据需要同步。呵呵

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
5 [报告]
发表于 2004-08-06 11:35 |只看该作者

求助:那位能够提供rsync的详细参数说明啊?

看来用这个的人还真不少。

虽然这个服务比较烂,但是也算上最经济实惠的了。。

论坛徽章:
0
6 [报告]
发表于 2004-08-06 22:23 |只看该作者

求助:那位能够提供rsync的详细参数说明啊?

rsync总是被动的接受客户端的同步请求。
请问如何使得rsync服务端主动的向客户段推送最新的文件呢?

论坛徽章:
0
7 [报告]
发表于 2004-08-07 03:05 |只看该作者

求助:那位能够提供rsync的详细参数说明啊?

原帖由 "peng" 发表:
看来用这个的人还真不少。

虽然这个服务比较烂,但是也算上最经济实惠的了。。

老peng
这烂字怎么讲
有什么劣迹吗?

论坛徽章:
0
8 [报告]
发表于 2008-06-23 13:15 |只看该作者
正在研究总是出问题。。。

论坛徽章:
0
9 [报告]
发表于 2008-06-23 13:31 |只看该作者
原帖由 1330313150 于 2008-6-23 13:15 发表
正在研究总是出问题。。。


这坟掘得
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP