cwRsync设置及使用
2010-07-28 11:17:25 阿炯

cwRsync是运行于Windows平台的支持跨平台进行数据同步机制,是Windows平台的 rsync 解决方案。对于rsync数据同步经常会遇到一些问题,下面的对于这些问题的解决,一定要逐一测试。

cwRsync - Rsync for Windows

cwRsync is a packaging of Rsync for Windows with a client GUI. You can use cwRsync for fast remote file backup and synchronization.

---------------------------------------
cwRsync安装配置的简单过程

ITeFix下载cwRsync,选择Free(免费版本),新的版本已经包括了客户端(cwRsync)和服务器端(cwRsyncServer)。服务端需要配置rsyncd.conf。

例如:
[test]
path=e:/test
comment=Data Backup for hto's laptop
read only=no
use chroot=no
strict modes = no
transfer logging=yes
use lfs=yes
hosts allow=172.25.43.57
hosts deny=*
/*上面是设置了一个test模块,相关配置在下面解释*/
5、重起服务端cwRsyncServer。
6、搭建已经完毕,可以开始命令操作。

一:修改cwRsyncServer配置文件 d:\cwRsyncServer\rsyncd.conf
#########
port = 52326
use chroot = false
strict modes = false
read only = yes
list = no
hosts allow = *
max connections = 10
secrets file = rsyncd.secrets #指定用户登录的密码文件
motd file = rsyncd.motd #连接上rsync server时显示的欢迎信息
log file = rsyncd.log
pid file = rsyncd.pid
transfer logging = yes
# Module definitions
# Remember cygwin naming conventions : c:\work becomes /cygwin/c/work
#
[test]
path = /cygdrive/d/tmp
read only = true
transfer logging = yes

[freeoa]
path = /cygdrive/c/work
read only = false
transfer logging = yes
#################################

二:在E:\cwRsyncServer目录下新建密码文件 rsyncd.secrets 内容为用户名:密码
如:freeoa:ccyou_d

下载cwRsync客户端(cwRsync)
安装目录: d:\cwRsync

三:在d:\cwRsyncServer目录下新建密码文件 rsyncd.secrets 内容为密码
如:ccyou_d

四:开始–>运行–>cmd 输入以下命令即可同步服务器端freeoa模块到客户端e:/y目录下。
E:\cwRsync\bin\rsync.exe -vazu –exclude article/ --progress --delete --password-file=E:\cwRsync\rsyncd.secrets rsync://hto@myipaddress:52326/freeoa /cygdrive/e/y

可按此做同步服务,如果不行:
1.检查服务器是否有开服务端口,命令行输入(netstat -a) 可查看服务器开的端口,就是上面的52326端口。
2.客户端命令行输入(telnet 服务端ip 服务端口) 能否连接服务器端。
3.检查配置文件是否跟上面一样。

注:以上为匿名连接入服务器端,一般会在模块里添加 auth user= hto 指定用户,一定要注意,指定的用户必须要登陆才能进行同步服务。

---------------------------------------
使用参考语法:(相关模块或目录最后都要加'/')

cd /d d:\programfiles\cwRsync\bin
rsync.exe --verbose --list-only --password-file=/cygdrive/d/data/rsync.passwd hto@192.168.0.3::material

注:仅列出服务器的'material'模块下的目录或文件列表

rsync.exe --archive -v /cygdrive/d/sd/upload/docs/ hto@192.168.1.10::home/docs/

注:将D盘下'sd/upload/docs/'目录中的文件同步到服务器'home'模块所指的'docs'目录

rsync.exe --archive --recursive --copy-dirlinks --keep-dirlinks --times --compress --8-bit-output --links --perms --owner --group --human-readable --force --delete --verbose --password-file=/cygdrive/d/data/rsync.passwd  /cygdrive/d/docs/system/ hto@192.168.0.3::material/docs/system/

注:将d盘下docs/system/中的内容同步到服务器的'material'模块下的docs/system/目录中

rsync.exe --archive --recursive --copy-dirlinks --keep-dirlinks --times --compress --8-bit-output --links --perms --owner --group --human-readable --force --delete --verbose --password-file=/cygdrive/d/data/rsync.passwd hto@192.168.0.3::material/unix/ /cygdrive/d/docs/unix/

注:将'material'模块下的unix目录中的文件同步到本地的d盘下/docs/unix/目录中
这里添加了'--delete'选项,这样会删除源目录中没有而目标目录中存在的文件,所以在回车执行前请确定是否要这么做!

---------------------------------------

相关问题集

关于对'ignore errors'这个错误处理选项的理解,这个选项最好加上,否则再很多时候发生不可知的错误,日志也不是经常再看,不加上这个出现错误的几率相对会很高。

chown出错
rsync: chown "" failed: Invalid argument (22)
rsync failed: Invalid argument (22)
这个错误发生在'chown'时,如向nfs、fat32、ntfs格式的磁盘上同步时,且使用了'-a'参数时,就会发生此类提示。可以使用'--no-owner --no-group'这两个参数来跳过'chown'过程。
可使用'-rlptD'参数来代替'-a',因为'-a = -rlptgoD',而'-rlptD'参数实际上就是去掉了'--owner --group',可解决此问题。
rsync.exe -a -v --no-owner --no-group hto@192.168.1.10::home/edu/techdoc /cygdrive/d/sd/

当然也可在rsync服务器上配置,让客户端在下载文件时,不调用'chown'过程。可以配置'refuse options = o g' 这项即可。

服务器上目录问题
包括目录是否存在、权限是否正确。
@ERROR: chroot failed
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.x]

指定的模块是否存在
服务器是指定模块不存在,需要提供正确的模块名或在服务器端修改成相应的模块可解决此问题。
@ERROR: Unknown module 'freeoa'
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.x]

模块认证出错
服务器端该模块(freeoa)需要验证用户名密码,但客户端没有提供正确的用户名密码而导致认证失败。
@ERROR: auth failed on module freeoa
rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.x]

服务器配置文件有误
rsyncd.conf配置文件内容有错误,请正确核对配置文件。具体可以参考:rsync服务器使用配置入门
rsync error: error starting client-server protocol (code 5) at main.c(1524) [Receiver=3.0.x]

主机或服务不可访问
主机没有开启、防火墙阻挡等,rsync服务对应tcp udp的873端口打开不可用所导致。
rsync: failed to connect to 192.168.1.10: No route to host (113)
rsync error: error in socket IO (code 10) at clientserver.c(104) [receiver=2.6.9]

密码文件权限不对
这是因为'rsyncd.pwd'、'rsyncd.secrets'文件的权限不对,应该设置为600。这样即使密码正确也不会使用而要求用户手动输入密码。
password file must not be other-accessible
continuing without password file
Password:

锁文件没有定义
配置文件 rsync.conf 中没有添加'lock file = rsyncd.lock'。
@ERROR: failed to open lock file
rsync error: error starting client-server protocol (code 5) at main.c(1495) [receiver=3.0.x]

配置文件中设置的 path 路径不存在,要新建目录才能继续同步(当然还要注意权限)
@ERROR: chroot failed
rsync: connection unexpectedly closed (75 bytes read so far)
rsync error: error in rsync protocol data stream (code 12) at io.c(150)

是配置选项host allow的问题
@ERROR: access denied to www from unknown (192.168.20.123)
rsync: connection unexpectedly closed (0 bytes received so far) [receiver]
rsync error: error in rsync protocol data stream (code 12) at io.c(359)

服务端服务没有被正常启动,看服务器进程是否存在或是否工作正常
rsync error: received SIGINT, SIGTERM, or SIGHUP (code 20) at rsync.c(244) [generator=2.6.9]
rsync error: received SIGUSR1 (code 19) at main.c(1182) [receiver=3.0.x]

多为防火墙问题导致,这个最好先彻底关闭防火墙或在其中放行
rsync: failed to connect to 218.107.243.2: No route to host (113)
rsync error: error in socket IO (code 10) at clientserver.c(104)

权限及时间问题引起的警告
rsync: failed to set times on "directory" Operation not permitted (1)
原因:两台机器的时间有差别(差几秒也算是)。还有一个原因,这个问题就是,因为 /etc/rsync.conf 文件内,你指定的uid、gid的问题,这样在同步文件要写的目录,其属主和属组都要是/etc/rsync.conf 文件内指定的uid、gid。可依据配置文件,把目标服务器的目标目录,改变目录的属主和属组。否则即使目录具有全部写权限也同样报这个警告。即使使用了-o、-g,同步到目的文件夹的文件用户和组都变成了同步使用的用户,但是用-p后文件权限可以保留。当目的文件夹(或文件)事后做过修改使属主不是rsync使用的用户,即使该目录的权限是777,也会出现上述错误。

因服务器配置文件写错而导致的问题
rsync: read error: Connection reset by peer (104)
rsync error: error in socket IO (code 10) at io.c(785) [sender=3.1.2]

日志有提到,但后面却误报出了该共享模块只读的提示。
2018/03/26 16:48:26 [8977] Badly formed boolean in configuration file: "fasle".
2018/03/26 16:48:26 [8977] name lookup failed for 192.168.0.20: Name or service not known
2018/03/26 16:48:26 [8977] connect from UNKNOWN (192.168.0.20)
2018/03/26 08:48:26 [8977] rsync to tmp/ from UNKNOWN (192.168.0.20)
2018/03/26 08:48:26 [8977] ERROR: module is read only
2018/03/26 08:48:26 [8977] rsync error: syntax or usage error (code 1) at main.c(994) [Receiver=3.1.2]

原来是将配置文件中的属性写错了:
read only = fasle
=>
read only = false


rsync同步时因配置文件中的用户与实际运行用户不同时密码文件权限问题报模块无法认证的问题

Sep  8 09:33:02 freeoa rsyncd[31805]: Unknown Parameter encountered: "wirte only"
Sep  8 09:33:02 freeoa rsyncd[31805]: IGNORING unknown parameter "wirte only"
Sep  8 09:33:02 freeoa rsyncd[31807]: Unknown Parameter encountered: "wirte only"
Sep  8 09:33:02 freeoa rsyncd[31807]: IGNORING unknown parameter "wirte only"
Sep  8 09:33:02 freeoa rsyncd[31806]: connect from freeoa (192.168.13.210)
Sep  8 09:33:02 freeoa rsyncd[31805]: connect from freeoa (192.168.13.210)
Sep  8 09:33:02 freeoa rsyncd[31807]: connect from localhost (127.0.0.1)
Sep  8 09:33:02 freeoa rsyncd[31806]: rsync: read error: Connection reset by peer (104)
Sep  8 09:33:02 freeoa rsyncd[31806]: rsync error: error in rsync protocol data stream (code 12) at io.c(764) [Receiver=3.0.9]
Sep  8 09:33:02 freeoa rsyncd[31807]: rsync: connection unexpectedly closed (0 bytes received so far) [Receiver]
Sep  8 09:33:02 freeoa rsyncd[31807]: rsync error: error in rsync protocol data stream (code 12) at io.c(605) [Receiver=3.0.9]

rsync -hriPtv --password-file=/etc/rsync.passwd freeoa@192.168.13.210::sc/data-* /srv/service/

Sep  8 09:41:24 freeoa rsyncd[4810]: name lookup failed for 192.168.10.73: Name or service not known
Sep  8 09:41:24 freeoa rsyncd[4810]: connect from UNKNOWN (192.168.10.73)
Sep  8 09:41:24 freeoa rsyncd[4810]: secrets file must be owned by root when running as root (see strict modes)
Sep  8 09:41:24 freeoa rsyncd[4810]: continuing without secrets file
Sep  8 09:41:24 freeoa rsyncd[4810]: auth failed on module sbzsc from UNKNOWN (192.168.10.73): missing secret for user "cldbsa"


---------------------------------------
windows与linux间rsync文件

1. windows上安装cwRsync,linux上安装openssh和rsync

2. 建立home和.ssh目录
home建在哪里自己定,可直接在cwRsync目录下面建了个home。
注意:'.ssh'目录的建立,直接在资源管理器里面建是不行的,需要在cmd下:mkdir ".ssh",用引号。

3. 将cwRsync目录下cwrsync.cmd开头的几个set命令跑一遍
 SETLOCAL
 SET CWRSYNCHOME=%PROGRAMFILES%\CWRSYNC
 SET HOME=[刚才建立的home,例如d:\programfiles\cwRsync\home\admin]
 SET CWOLDPATH=%PATH%
 SET PATH=%CWRSYNCHOME%\BIN;%PATH%

4. 生成private/public key:ssh-keygen -t rsa -N ''
生成的key会在.ssh下面,可以拷到其它目录以方便使用,例如d:

5. 将key加到linux服务器的authorized_keys里面:
如果服务器账号下面本身没有authorized_keys,那么直接用下面这个命令即可:rsync -av "/cygdrive/d/id_rsa.pub" [linuxuser]@[linuxipaddress]:.ssh/authorized_keys

如果已经有了,那么还是上传到一个新文件: rsync -av "/cygdrive/d/id_rsa.pub" [linuxuser]@[linuxipaddress]:.ssh/new_key
然后再linux上把新的key加进去: cat new_key >>authorized_keys
这里跑rsync的时候会提示你输入linuxuser的密码,key上传以后就不需要了。

6. 将cwrsync.cmd模板复制成一个新的文件
例如:mysync.cmd,修改里面的home,然后再最后加入实际需要跑的rsync命令。例如我这个是从linux服务器sync到我windows机器:     rsync -avz [linuxuser]@[linuxipaddress]:[服务器路径] [本地cygwin式路径,例如:/cygdrive/d/....]

从win同步到linux则把两个路径换一下位置就行了。

7. 然后就可以直接跑mysync.cmd了。

说明:2-5步其实是配置ssh免密码登录到linux,实际以后每次的同步就是跑一下第7步的脚本,如果需要增加新的同步目录,只需要编辑一下这个脚本加一行。2-5步对其它利用ssh免密码登录的同步方式或工具都是需要的。

---------------------------------------
配置文件选项说明

-v, --verbose 详细模式输出
-q, --quiet 精简输出模式
-c, --checksum 打开校验开关,强制对文件传输进行校验
-a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
-r, --recursive 对子目录以递归模式处理
-R, --relative 使用相对路径信息
其他参数可以查看rsync相关手册。

相关解释(Linux服务端):
uid = nobody
gid = nobody
use chroot = no         # 不使用chroot
max connections = 4         # 最大连接数为4
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log    # 日志记录文件
[hto]            # 这里是认证的模块名,在client端需要指定
path = /home/hto/python/    # 需要做镜像的目录
comment = BACKUP CLIENT IS SOLARIS 8 E250
ignore errors            # 可以忽略一些无关的IO错误
read only = yes            # 只读
list = no            # 不允许列文件
hosts allow=172.25.43.57  #允许连接IP
auth users = hto        # 认证的用户名,如果没有这行,则表明是匿名
secrets file = /etc/hto.pas    # 认证文件名

注:为安全考虑,在设置服务端rsyncd.conf模块时,最好加上auth users = hto,secrets file = /etc/hto.pas,密码写到一个文件中hto.pas。
执行命令时:rsync -avrp /test/hto@172.16.33.158::test --password-file=hto.pas。

-------------------------------------
rsync参数详解

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

-------------------------------------
参考来源


跨平台用Rsync来同步文件

rsync服务器使用配置入门

该文章最后由 阿炯 于 2020-09-12 20:11:15 更新,目前是第 3 版。