rsync的使用方法 
一、设置Rsync Server端 
Rsync server需要设定四个方面: 
1.规划建立备份目录区 
2.设定: /etc/xinetd.d/rsync 
3.设定: /etc/rsyncd.conf 
4.设定: 密码文件。

说明如下: 
1.规划建立备份目录区: 
建议你在rsync server上开一个较大的磁盘分割区,并在其下建立好备份用的目录。比如:/home/asialinux。 
2.设定: /etc/xinetd.d/rsync: 
即#vi /etc/xinetd.d/rsync 
#default: off 
#description:The rsync server is a good addition to am ftp server,as it 
#    allows crc checksumming etc. 
service rsync 

    disable = no 
    socket_type   = stream 
    wait      = no 
    user      = root 
    server     = /usr/bin/rsync 
    server_args   = --daemon 
    log_on_failure += USERID 

把其中的disable = yes 改为 disable = no之后退出保存就可以了,这还没有完成,还需启动rsync的服务。 
#service xinetd restart 
或者 
#ntsysv 
选中 
rsync确定即可。 
这样就开通了873通道(port),一旦有rsync client连接,xinetd就会把它转介给rsyncd跑port873。

#lsof -i:873

3.设定: /etc/rsyncd.conf 
如果在/etc下没有这个文件,请不要迷惑,自己创建一个不就得了,假设要备份的机器名为asialinux(IP:192.168.0.1), 
即Samba文件服务器: 
#vi /etc/rsyncd.conf 
uid = nobody 
gid = nobody 
use chroot = no 
max connections = 4 
pid file = /var/run/rsyncd.pid 
lock file = /var/run/rsync.lock 
log file = /var/log/rsyncd.log 
secrets file = /etc/rsync.pass

[backup] 
path = /home/server/asialinux   ##没有斜杠
auth users = feixue 
uid = root 
gid = root 
secrets file = /home/rsyncd.secrets 
read only = no 
退出vi编辑模式并保存。

说明: 
[backup]代表欲备份的主机代号,可以和主机名相同,也可以自定。本例为backup,而没有用asialinux以便大家在下面使用rsync命令时加以理解。 
Path就是用来存放备份档案的绝对目录,请你一定要用mkdir开设好,名称自定,如本例要在/home目录下面建立server目录以及server下面的子目录asialinux。 
注:如果你没有建立目录、目录建立的不对或者路径不对,都将不能进行rsync的备份,情况如下所示: 
#rsync –rvlHopDtS --password-file=/root/rsyncd.recrets /home feixue@testsmb::backup 
@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(165)

auth users代表授权的账号,名称可自定。 
secrets file代表存储账号和密码的档案路径。

当然,大家可以在/etc/rsyncd.conf内加入更多的区块,来备份多台主机或者一台主机的多个目录等,可以灵活运用。

4.设定:密码文件 
如果没有和ssh在一块儿运用的话,rsyncd.secrets的内容很简单,格式为 账号:密码 
例如: 
feixue:asialinux 
注:上述设定只是一个范例,请大家务必自定一组,千万不可以直接套用。 
账号和密码设定完成之后,为了安全,还要对其属主和权限进行限定,我测试过,server和client端的权限都设为000时,只要密码两者相符,依然可以正常的备份。:D 
#chown root.root rsyncd.secrets 
#chmod 600 rsyncd.secrets 
这样,我们的Rsync Server端就设定完成了,当然你可以查看rsync的记录日志档案,请参考:/var/log/rsyncd.log。

二、设置Rsync Client端 
假设欲备份的机器名称为testsmb(IP:192.168.2.220)下的目录/home备份到Rsync Server(asialinux)上。可以做如下设定: 
 1.设定密码文件 
 2.测试rsync执行指令 
 3.将rsync指令放入工作排程(crontab) 
说明如下: 
1.设定密码文件 
假设把密码文件放在/root/rsyncd.secrets,内容很简单,只要含有一行密码即可: 
#vi /root/rsyncd.secrets 
asialinux 
退出vi编辑模式并保存。 
注:为了安全,设定密码档案的属性为:600。rsyncd.secrets的密码一定要和Rsync Server密码设定档案里的密码一样。 
如果不同,将会出现如下的错误: 
#rsync –rvlHopDtS --password-file=/root/rsyncd.secrets /home feixue@asialinux::backup 
@ERROR: auth failed on module backup 
rsync: connection unexpectedly closed (90 bytes read so far) 
rsync error: error in rsync protocol data stream (code 12) at io.c(165) 
2. 测试rsync执行指令 
一切设定完之后,我们可以带着兴奋的心情来测试、体验一下Rsync的魅力吧:) 
# rsync –rvlHopDtS --password-file=/root/rsyncd.secrets /home feixue@asialinux::backup 
如果出现如下所示的画面,那么恭喜一下,成功了:

上传备份 
# rsync -rvlHopDtSP --password-file=/root/rsyncd.secrets /home/db_epp1/ feixue@183.230.40.230::backup &

下载备份 
#  rsync -rvlHopDtSP --password-file=/root/rsyncd.secrets  feixue@183.230.40.230::backup /home/db_epp1/ &

building file list ... done 
.profiles/Application Data/Microsoft/Office/WEBFDR16.INF 
.profiles/Application Data/Microsoft/WELCOME/DEFAULT.WBM

若出现如下: 
# rsync –rvlHopDtS --password-file=/root/rsyncd.secrets /home feixue@asialinux::backup 
rsync: getaddrinto: testsmb 873: Name or service not know 
rsync error: error in socket IO (code 10 ) at clientserver.c(83)

请分别编辑Rsync Server(假设hostname为asialinux,IP:192.168.0.1)和Rsync Client(假设hostname为testsmb,IP:192.168.0.2)的/etc/hosts文件,分别加入对方的IP地址和机器名,如下: 
[root@asialinux root]#vi /etc/hosts 
192.168.0.2    testsmb 
退出vi编辑模式并保存。 
[root@testsmb root]#vi /etc/hosts 
192.168.0.1    asialinux 
退出vi编辑模式并保存。 
如果没有出现期望的画面,那么请检查一下你的设定。

3.将rsync指令放入工作排程(crontab) 
现在可以把我们的备份工作置入排程了,假设每天凌晨1点开始备份工作: 
#crontab –u root –e 
0 1 * * * /usr/bin/rsync --password-file=/root/rsyncd.secrets /home feixue@asialinux::backup 
如果你有其他的目录需要备份,则如法炮制吧

@rsync 试用参数: 
-h , --help 显示rsync求助资讯 
--version 顯示rsync版本 
-v , --verbose 复杂的输出信息 
-q , --quiet 安静模式,几乎没有讯息产生, 常用在以cron执行rsync 
-I, --ignore-times 通常rsync为了加快速度会忽略同样档案大小且同样,同样存取时间点的档案 
可以通过此参数开关此快速检查. 
--size-only rsync  只检查档案大小是否改变,不管时间存取点是否改变 
通常用在mirror, 且对方时间不太正确时 
-c, --checksum 在传送之前透过128bit的md4检查码来检查所有要传送的档案(会托满速度); 
-a, --archive archive mode 权限保存模式,相当于 -rlptgoD 参数. 
很快速的保存几乎所有的权限设定,除了硬式连接(透过-H设定). 
-r, --recursive 复制所有下面的资料(透过) 
-R, --relative 使用相对路径 
如: rsync foo/bar/foo.c remote:/tmp/ 在远端产生/tmp/foo.c档案 
rsync -R foo/bar/foo.c remote:/tmp/ 在远端产生/tmp/foo/bar/foo.c 档案 
-R, --relative 不使用相对路径 
-b, --backup 目的地端先前已经存在的档案在传输或删除前会被备份 
--backup-dir=DIR 设定备份的资料夹 
--suffix=SUFFIX 指定备份的档案名称字尾形式(预设为~) 
-K, --keep-dirlinks 接收方将连接到资料夹的档案视为资料夹处理 
-l, --links 复制所有的连接 
-H, --hard-links 保留硬式连结 
-p, --perms 保留档案权限 
-o, --owner 保留档案所有者(root only) 
-g, --group 保留档案群组 
-D, --devices 保留device资讯(root only) 
-t, --times 保留时间点 
-n, --dry-run 不实际执行传送, 只显示将会有的传输动作 
-S, --sparse 尝试去处理稀疏的档案, 让这些档案在目的端占去较少的磁碟空间 
-W, --whole-file 复制所有的档案, 不额外作检查 
--no-whole-file 关闭 --whole-file 参数 
-x, --one-file-system 不要跨越档案系统分界(只在一个档案系统处理) 
-B, --block-size=SIZE 强制透过rsync程式去比对修复block-sizeforce 
-e --rsh=COMMAND 定义所试用的remote shell 
--rsync-path=PATH 定义rsync在远端机器存放资料的路径 
--existing 只对比更新目的端已经存在的档案 
--ignore-existing 忽略目的断已经存在的档案(也就是不更新) 
--delete 删除传送断已经不存在,而目的端存在的档案 
--delete-excluded 除了把传送端已经不存在, 而目的端存在的档案删除之外, 也删除 --exclude 参数所包含的档案 
--delete-after rsync预设会在档案传送前进行相关删除动作确保接收端有足够的档案空间, 
单可以透过 --delete-after 让删除动作在档案传送后在进行删除 
--ignore-errors 忽略任何错误即使是I/O error 也进行 --delete 删除动作 
--max-delete=NUM 定义rsync不要删除超过NUM个档案 
--partial rsync若遇到传输过程中断时, 会把那些已经传输的档案删除. 
在某种状况下保留那些部分传送的档案是令人高兴的; 
你可以透过 --partial 参数达到这个目的. 
--partial-dir=DIR 在 --partial 参数启动时, 你还是可以定义rsync把那些部分传送的档案 
写入定义的资料夹, 而非直接写入目的端,需要注意的是, 
此资料夹不应该被其他试用者可以写入.(如:/tmp) 
--force 当目的端资料夹被传送端非资料夹名称覆盖时, 强制rsync删除资料夹, 即使该资料夹不是空的. 
--numeric-ids 不将传送端档案的uid及gid值, 与目的端的使用者/群组进行配对, 
若传送端并没有uid及gid的对应名称(如:原帐号群组被删除的遗留档案), 
或目的端没有相对应的帐号/群组, 保留数字型式的uid/gid 
--timeout=TIMEOUT 设定I/O 超时的时间(秒). 超过这个秒数而没有资料传送, rsync将会结束. 预设为0,也就是没有定义超时时间 
-T, --temp-dir=DIR 定义rsync在接收端产生暂时性的复制档案时使用资料夹暂存, 预设时直接在接收端资料夹直接产生暂存档案 
--compare-dest=DIR 定义rsync在目的端建立资料夹来比对传送过来的档案. 
--link-dest=DIR 与 --compare-dest 相同,但同时会针对无法改变的档案建立硬式连结. 
-z, --compress 压缩模式, 当资料在传送到目的端进行档案压缩. 
-P -P参数和 --partial --progress 相同.只是为了把参数简单化. 
-C, --cvs-exclude 排除那些通常不希望传送的档案, 定义的方式与CVS传送相同: 
RCS SCCS CVS CVS.adm RCSLOG cvslog.* tags TAGS .make.state 
.nse_depinfo *~ #* .#* ,* _$* *$ *.old *.bak *.BAK *.orig *.rej 
.del-* *.a *.olb *.o *.obj *.so *.exe *.Z *.elc *.ln core .svn/ 
符合以上条件的都会被忽略不传送. 
--exclude=PATTER 符合PATTERN(规则表示式)样式的档案不仅行传送 
--exclude-from=FILE 和 --exclude 参数相同, 不过是把不进行传送的档案事先写入某一档案. 
执行时, 透过此参数让rsync读取. 
(; #开头的行列或者空白会被rsync忽略) 
--include=PATTERN 定义rsync不要排除符合pattern样式的档案 
--include-from=FILE 和--include参数相同,只不过把要包含的档案写到某一档案. 
--files-from=FILE 把要传送的档案名称都精确的写入某一档案, 让rsync读取. 
如: rsync -a --files-from=/tmp/foo /usr remote:/backup 
-0 --from0 定义档案所要读取的档案时null字元结尾. 
--version 现四版本信息. 
--daemon 定义rsync以daemon型态执行 
--no-detach 当以daemon形态执行时,不要进行分裂且变成背景程序. 
--address=ADDRESS 定义所要连接(bind)的ip位置或者是host名称(daemon限定) 
--config=FILE 定义所要读取的设定档rsyncd.conf位置(daemon限定) 
预设值为 /usr/local/etc/rsyncd.conf 
--port=PORT 定义rsyncd(daemon)要旨行的port(预设为tcp 873) 
--blocking-io 使用blocking I/O连结远端的shell, 如rsh, remsh 
--no-blocking-io 使用non-blocking连结远端的shell, 如ssh(预设值) 
--stats 显示档案传送时的资讯状态 
--progress 显示传送的进度.(给档案传送时,怕无聊的人用的..) 
--log-format=FORMAT 定义log的格式(在rsyncd.conf设定) 
--password-file=FILE 从档案读取与远端rsync伺服务连结的密码 
--bwlimit=KBPS 定义传输频宽的大小(KBytes/秒) 
--write-batch=FILE 把记录资料写入一个档案(给其他相同环境且相同需求的机器试用) 
--read-batch=FILE 透过读取记录档案来进行传输.(档案由 --write-batch 参数产生) 
--checksum-seed=NUM 定义档案 checksum-seed 的大小(byte) 
-4 --ipv4 使用IPv4协定 
-6 --ipv6 使用IPv6协定

Rsync数据远程同步备份的更多相关文章

  1. CentOS 6.5 rsync+inotify实现数据实时同步备份

    CentOS 6.5 rsync+inotify实现数据实时同步备份 rsync    remote sync 远程同步,同步是把数据从缓冲区同步到磁盘上去的.数据在内存缓存区完成之后还没有写入到磁盘 ...

  2. Linux Rsync实现文件同步备份(转载)

    原文地址:Linux Rsync实现文件同步备份作者:夷北 转自:http://www.mike.org.cn/blog/index.php?load=read&id=639###pp=0 [ ...

  3. Linux下简单粗暴使用rsync实现文件同步备份【转】

    这篇来说说如何安全的备份,还有一点不同的是上一篇是备份服务器拉取数据,这里要讲的是主服务器如何推送数据实现备份. 一.备份服务器配置rsync文件 vim /etc/rsyncd.conf #工作中指 ...

  4. rsync+sersync自动同步备份数据

    一.为什么要用Rsync+sersync架构?1.sersync是基于Inotify开发的,类似于Inotify-tools的工具2.sersync可以记录下被监听目录中发生变化的(包括增加.删除.修 ...

  5. Rsync(远程同步): linux中Rsync命令的实际示例

    rsync的 ( 远程同步 )为在Linux / Unix系统局部 拷贝和同步文件和目录远程以及一个最常用的命令. 随着rsync命令的帮助,您可以复制并在目录中远程和本地同步数据,在磁盘和网络,进行 ...

  6. 如何通过rsync+sersync 实现同步备份

    3.rsync+sersync更快更节约资源实现web数据同步4.unison+inotify实现web数据双向同步 一:为什么要实现同步备份 服务器上有些重要文件或数据时,可以把他们多备份一份到其他 ...

  7. Rsync + sersync 实时同步备份

    一      Rsync + Sersync  实时同步介绍 1.Rsync 服务搭建介绍 云机上搭建Rsync server,在本地搭建Rsync Clinet. 2. Sersync 服务搭建介绍 ...

  8. centos7下rsync+crontab定期同步备份

    最近需求想定期备份内部重要的服务器数据到存储里面,顺便做个笔记 以前整过一个win下的cwrsync(客户端)+rsync(服务端:存储)的bat脚本 这次整一个Linux下的脚本sh,执行定期自动备 ...

  9. rsync数据定时增量备份知识管理服务器数据

    为了保证公司知识管理服务器数据的安全性,所以计划每天同步confluence服务器上面数据 一.安装rsync服务端 1.查看是否安装rsync ps -ef | grep rsync 2.添加配置文 ...

随机推荐

  1. git中添加多个SSH公钥,以及不同系统之间的差别

    git学习已经也有一段时间了,基本的操作,口令会了一点点,但是还没有git团队开发的实践,这个有待加强~ git是在windows下面模拟Linux环境的,linux自带的ssh服务,可以通过该服务远 ...

  2. Centos6.3手动rpm安装gcc,c++

    如果你的服务器是不能上网的,那就说明你要手动安装很多软件,比如gcc; 1,首先到http://vault.centos.org/6.3/os/x86_64/Packages/下载用到的rpm包,包括 ...

  3. hdu 3631 Shortest Path

    floyd算法好像很奇妙的样子.可以做到每次加入一个点再以这个点为中间点去更新最短路,效率是n*n. #include<cstdio> #include<cstring> #i ...

  4. Sublime Text 2

    常用功能: 安装Package Control:https://sublime.wbond.net/ 多行选择.多行编辑鼠标选中多行,按下 Ctrl+Shift+L (Command+Shift+L) ...

  5. POJ 3041 Asteroids(匈牙利+邻接表)

    ( ̄▽ ̄)" #include<iostream> #include<cstdio> #include<cstring> #include<algo ...

  6. hdu_4918_Query on the subtree(树的分治+树状数组)

    题目链接:hdu_4918_Query on the subtree 题意: 给出一颗n个点的树,每个点有一个权值,有两种操作,一种是将某个点的权值修改为v,另一种是查询距离点u不超过d的点的权值和. ...

  7. 8.Hibernate的多对多关联映射

    1.创建如下数据库脚本 --1.1 项目表 create table PROJECT ( proid ) not null, proname ) ) ; --1.2 项目表主键 alter table ...

  8. git上传代码到github

    git上传代码到github [root@bigdata-hadoop- ~]# git init [root@bigdata-hadoop- ~]# git add zeppelin [root@b ...

  9. Chapter 14_2 全局变量声明

    Lua中的全局变量不需要声明就可以使用.对于小程序十分方便,但是大型程序中 一处简单的笔误就可能造成难以发现的bug. 不过,这种性能可以改变.由于Lua将全局变量放在一个普通的table中,可以通过 ...

  10. ios书籍推荐

    1.Objective-C Programming  内容不多, 却都是精华, 有了一点 C 语言基础可以快速阅读此书, 大概一天时间就可以看完, 看完后对 iOS 开发能够有个基本的印象. 2.iO ...