Windows下cwRsync搭建步骤
文章(一)
CwRsync是基于cygwin平台的rsync软件包,支持windows对windows、windows对Linux、Linux对windows高效文件同步。由于CwRsync已经集成了cygwin类库,因此安装的时候可以省去cygwin包。Cwrsync还集成了OpenSSH for windows,可以实现Linux 下Rsync一模一样的操作。详细配置步骤如下:
一、服务器端安装配置
这一步很重要,可以说是cwRsync安装成功与否的关键。这一步会在当前系统下生成 SvcCWRSYNC 一个账户,用来启动RsyncServer服务。建议这个对此账户的密码进行重新设置,重新设置密码(如start-888)后,需要在服务中更改,否则 RsyncServer服务 不能启动
程序自动设置程序目录可修改的权限,因为需要写日志文件。
3、修改配置文件rsyncd.conf
use chroot = false
strict modes = false
hosts allow = *
log file = rsyncd.log
# Module definitions
# Remember cygwin naming conventions : c:\work becomes /cygwin/c/work
#
[test]
path = /cygdrive/c/work
read only = false
transfer logging = yes
修改配置内容如下,参数解释:
use chroot = false # 不使用chroot
strict modes = false #使用静态模式
[test] # 这里是认证的模块名,在client端需要指定
path = /cygdrive/e/bak # 需要做镜像的目录,如e/bak(此目录需要给 SvcCWRSYNC 账户的读取权限)
transfer logging = yes # 记录传输日志
read only = yes # 只读
list = no # 不允许列文件
hosts allow = 12.0.2.5/255.255.252.0 # *表示允许任意IP
uid = 0 #解决运行后的@ERROR: invalid uid 错误
gid = 0 #解决运行后的@ERROR: invalid gid 错误
#auth users = SvcCWRSYNC # 认证的用户名,这里没有这行,则表明是匿名
#secrets file = /cygdrive/c/pass/rsync.passwd # 认证文件名
创建认证文件 c/pass/rsync.passwd 内容格式:用户:密码,如SvcCWRSYNC:start-888 启动RsyncServer服务并保证开机自动重启,服务器端配置完毕。
一直下一步,安装完成。
set RSYNC_HOME=c:\Program Files(x86)\cwRsync\bin
cd %RSYNC_HOME%
d:
rsync -av rsync://12.0.2.3/test /cygdrive/e/test
set RSYNC_HOME=c:\Program Files(x86)\cwRsync\bin
cd %RSYNC_HOME%
d:
#rsync -avzP --progress --delete --password-file=/cygdrive/c/pass/rsync.passwd SvcCWRSYNC@12.0.2.3::test /cygdrive/e/test
#
-avzP
-a 参数,相当于-rlptgoD,-r 是递归 -l 是链接文件,意思是拷贝链接文件;-p 表示保持文件原有权限;-t 保持文件原有时间;-g 保持文件原有用户组;-o 保持文件原有属主;-D 相当于块设备文件;
-z 传输时压缩;
-P 传输进度;
-v verbose,详细模式输出
-u是只同步已经更新的文件,避免没有更新的文件被重复更新一次,不过要注意两者机器时钟的同步
--progress
显示备份过程
--delete
删除那些DST中SRC没有的文件
--password-file
客户端指定密码文件,只需包含密码而不用包含用户名
SvcCWRSYNC@12.0.2.3::test
SvcCWRSYNC 登陆服务器端的用户名
12.0.2.3服务器端的ip地址
test 服务器端指定的认证模块名,多个同步作业靠此模块名区分
/cygdrive/e/test
存放服务器端同步文件的本地目录
4、配置系统作业,运行脚本选择rsync.bat,客户端配置完毕。
cwRsync是运用于windows 平台的数据同步机制,等于是Windows平台的 rsync 解决方案。对于rsync数据同步经常会遇到一些问题,下面的对于这些问题的解决,一定要逐一测试。
---------------------------------------
cwRsync安装配置的简单过程
1、从ITeFix下载cwRsync客户端(cwRsync)和服务器端(cwRsyncServer)。
2、在客户端安装cwRsync。
3、在服务端安装cwRsyncServer。
4、配置服务端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 内容为用户名:密码
如:tly: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'选项,这样会删除源目录中没有而目标目录中存在的文件,所以在回车执行前请确定是否要这么做!
---------------------------------------
相关问题集
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]
---------------------------------------
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 显示帮助信息
Windows下cwRsync搭建步骤的更多相关文章
- Redis的简单介绍及在Windows下环境搭建
简单介绍 1,Redis是什么 最直接的还是看官方的定义吧. Redis is an open source (BSD licensed), in-memory data structure stor ...
- [INS-30131] 执行安装程序验证所需的初始设置失败问题解决,windows下oracle安装步骤
[INS-30131] 执行安装程序验证所需的初始设置失败问题解决,windows下oracle安装步骤 配置: 系统:windows10 数据库:Oracle Database 12c 第 1 版 ...
- Windows下快速搭建安卓开发环境android-studio
Windows下快速搭建安卓开发环境android-studio 发布时间:2018-01-18 来源:网络 上传者:用户 关键字: 安卓 搭建 Android Windows 快速 环境 Studi ...
- Windows下IIS搭建Ftp服务器
第一步:启用Windows IIS Web服务器 1.1 控制面板中找到"程序"并打开 1.2 程序界面找到"启用或关闭Windows功能"并打开 1.3 上面 ...
- 比特币学习笔记(一)---在windows下编译搭建比特币环境
最近打算研究下比特币源码,却发现这套源码正常情况下得在linux下编译运行,而我的机器是windows的. 怎么办呢? 起初打算用mingw和cygwin搞搞看,试了许久后发现行不通,必须转到linu ...
- Nginx系列~概念与windows下环境搭建
概述 Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sys ...
- Windows下安装Nodejs步骤
最近打算把我们的微信端用Vue.js重构,为什么选择Vue.js,一是之前使用的是传统的asp.net mvc,多页面应用用户体验比单页面要差.二是使用过Angular.js,感觉对开发人员要求较 ...
- Apache Windows下Apache安装步骤
1.apache官网下载Apache HTTP Server服务器 我相信有些朋友刚用apache服务器时,都希望从官网上下载,而面对着官网上众多的项目和镜像以及目录,也许有点茫然.下面是具体步骤: ...
- 前端架构之路:Windows下安装Nodejs步骤
最近打算把我们的微信端用Vue.js重构,为什么选择Vue.js,一是之前使用的是传统的asp.net mvc,多页面应用用户体验比单页面要差.二是使用过Angular.js,感觉对开发人员要求较 ...
随机推荐
- LINQ学习入门教程(一)
LINQ 查询简介 Linq 是一跨各种数据源和数据格式的数据模型:它在查询是,始终是把它作为一种对象来操作,可以使用基本相同的编码模型查询和数据的转换XML,SQL,ADO数据等: Li ...
- IOS开发-UIBarButtonItem系统自带图标总结
1.这四个返回的是后面的单词. UIBarButtonSystemItemDone UIBarButtonSystemItemCancel UIBarButtonSystemItemEdit UIBa ...
- 剑指offer系列40----机器人的运动范围
package com.exe8.offer; /** *[题目]地上有一个m行和n列的方格.一个机器人从坐标0,0的格子开始移动, * 每一次只能向左,右,上,下四个方向移动一格,但是不能进入行坐标 ...
- IntelliJ IDEA中运行Tomcat报内存溢出(java.lang.OutOfMemoryError: PermGen space)
在Run/Debug Configuration中修改Tomcat的VM options,在里面输入以下内容: -server -XX:PermSize=128M -XX:MaxPermSize=25 ...
- grep 与正则表达式
正则表达式只是字符串的一种描述,只有和支持正则表达式的工具相结合才能进行字符串处理.本文以grep为例来讲解正则表达式. grep命令 功能:输入文件的每一行中查找字符串. 基本用法: grep [- ...
- application in 2014
OA WEBSITE ERP ISO ANDROID EF+MVC4+CATCHE+JQuery+js+div+css+web性能优化+webservice+sql2008+设计模式+wcf+多线程 ...
- (C/C++) Callback Function 回调(diao)函数
原文: http://www.codeguru.com/cpp/cpp/cpp_mfc/callbacks/article.php/c10557/Callback-Functions-Tutorial ...
- (WPF, Service) 删除注册表中的USB Enum值.
Task: 删除HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Enum\USB\VID_0XXX&PID_0XXX Key Tree 首先第一想到的使 ...
- MODBUS-寄存器与功能码学习
分类 简称 起始地址 结束地址 能够使用的功能码 输出逻辑线圈/(可读写位)/(DI/O)(如继电器开关控制) 0x 00000 09999 0x01读一组逻辑线圈 0x05写单个线圈 0x0f写多个 ...
- 使用matplot绘图 @python
1. 使用csv 模块读取数据 2. 定义label 3. 绘图,调参 #!/usr/bin/env python # coding=utf-8 import sys import matplotli ...