ubuntu 之 rsync

导言

rsync是类unix系统下的数据镜像备份工具,从软件的命名上就可以看出来了――remote sync。它的特性如下:
可以镜像保存整个目录树和文件系统。
可以很容易做到保持原来文件的权限、时间、软硬链接等等。
无须特殊权限即可安装。
优化的流程,文件传输效率高。
可以使用rcp、ssh等方式来传输文件,当然也可以通过直接的socket连接。
支持匿名传输,以方便进行网站镜象。
软件下载
rysnc的主页地址为:
http://rsync.samba.org/

首先提示:如果同步文件权限只是root用户,则后面的  auth users =root,这是必须的,不然会出现同步错误,密码可以随意,毫无影响同步  



安装

在ubuntu下安装rsync通过以下步骤可以实现: 
# apt-get install rsync xinetd

配置

1. 编辑/etc/default/rsync 启动rsync作为使用xinetd的守护进程
# vim /etc/default/rsync
RSYNC_ENABLE=inetd

2. 创建 /etc/xinetd.d/rsync 通过xinetd使rsync开始工作
# vim /etc/xinetd.d/rsync
service rsync
{
disable = no
socket_type = stream
wait = no
user = root
server = /usr/bin/rsync
server_args = --daemon
log_on_failure += USERID
}


3. 创建 /etc/rsyncd.conf 配置rsync使其在.(默认情况Ubuntu安装了rsync服务,但在/etc下没有配置文件,一般情况可以copy示例文件到/etc下

 #cp /usr/share/doc/rsync/examples/rsyncd.conf /etc)

# vim /etc/rsyncd.conf
max connections = 2
log file = /var/log/rsync.log
timeout = 300

[share]
comment = Public Share
path = /home/share
read only = no
list = yes
uid = nobody
gid = nogroup
auth users = user
secrets file = /etc/rsyncd.secrets

4. 创建 /etc/rsyncd.secrets 配置用户名和密码.
# vim /etc/rsyncd.secrets 
user:password

4.a
# chmod 600 /etc/rsyncd.secrets

5. 启动/重启 xinetd
# /etc/init.d/xinetd restart
[编辑]
测试

运行下面的命令检查,确认rsync配置成功。
# rsync [email protected]::share
Password:
drwxr-xr-x 4096 2006/12/13 09:41:59 .
drwxr-xr-x 4096 2006/11/23 18:00:03 folders


以上是服务器端配置
客户端不需要配置,如果想实现不用输入密码就可以同步的话,还是要稍加配置的:


6.设置工作任务,假设每天凌晨1 点开始备份:
先建立备份 Script 文件
 
范例:#vim /root/rsync.sh

#!/bin/bash
#
/usr/bin/rsync -av --password-file=/root/rsyncd.secrets --delete    --exclude="*.log" [email protected]::share   /home/share/   
-a, �Carchive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
-v, �Cverbose 详细模式输出
--password-file 指定client端密码文件存放路径
--delete
是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致
 --exclude="*.log"  不包含以.log结尾的文件


再创建密码文件,此文件在客户端,只写入密码
#vim   /root/rsyncd.secrets

password

改权限:#chmod 600  /root/rsyncd.secrets

最后执行 crontab:
crontab -e
加入:
0 1 * * * /root/rsync.sh




详细格式说明:
-v, �Cverbose 详细模式输出

-q, �Cquiet 精简输出模式

-c, �Cchecksum 打开校验开关,强制对文件传输进行校验

-a, �Carchive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD

-r, �Crecursive 对子目录以递归模式处理

-R, �Crelative 使用相对路径信息

-b, �Cbackup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为
~filename。可以使用�Csuffix选项来指定不同的备份文件前缀。

�Cbackup-dir 将备份文件(如~filename)存放在在目录下。

-suffix=SUFFIX 定义备份文件前缀

-u, �Cupdate 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。
(不覆盖更新的文件)

-l, �Clinks 保留软链结

-L, �Ccopy-links 想对待常规文件一样处理软链结

�Ccopy-unsafe-links 仅仅拷贝指向SRC路径目录树以外的链结

�Csafe-links 忽略指向SRC路径目录树以外的链结

-H, �Chard-links 保留硬链结

-p, �Cperms 保持文件权限

-o, �Cowner 保持文件属主信息

-g, �Cgroup 保持文件属组信息

-D, �Cdevices 保持设备文件信息

-t, �Ctimes 保持文件时间信息

-S, �Csparse 对稀疏文件进行特殊处理以节省DST的空间

-n, �Cdry-run现实哪些文件将被传输

-W, �Cwhole-file 拷贝文件,不进行增量检测

-x, �Cone-file-system 不要跨越文件系统边界

-B, �Cblock-size=SIZE 检验算法使用的块尺寸,默认是700字节

-e, �Crsh=COMMAND 指定替代rsh的shell程序

�Crsync-path=PATH 指定远程服务器上的rsync命令所在路径信息

-C, �Ccvs-exclude 使用和CVS一样的方法自动忽略文件,用来排除那些不希望传输的文件

�Cexisting 仅仅更新那些已经存在于DST的文件,而不备份那些新创建的文件

�Cdelete 删除那些DST中SRC没有的文件

�Cdelete-excluded 同样删除接收端那些被该选项指定排除的文件

�Cdelete-after 传输结束以后再删除

�Cignore-errors 及时出现IO错误也进行删除

�Cmax-delete=NUM 最多删除NUM个文件

�Cpartial 保留那些因故没有完全传输的文件,以是加快随后的再次传输

�Cforce 强制删除目录,即使不为空

�Cnumeric-ids 不将数字的用户和组ID匹配为用户名和组名

�Ctimeout=TIME IP超时时间,单位为秒

-I, �Cignore-times 不跳过那些有同样的时间和长度的文件

�Csize-only 当决定是否要备份文件时,仅仅察看文件大小而不考虑文件时间

�Cmodify-window=NUM 决定文件是否时间相同时使用的时间戳窗口,默认为0

-T �Ctemp-dir=DIR 在DIR中创建临时文件

�Ccompare-dest=DIR 同样比较DIR中的文件来决定是否需要备份

-P 等同于 �Cpartial �Cprogress 显示备份过程

-z, �Ccompress 对备份的文件在传输时进行压缩处理

�Cexclude=PATTERN 指定排除不需要传输的文件模式

�Cinclude=PATTERN 指定不排除而需要传输的文件模式

�Cexclude-from=FILE 排除FILE中指定模式的文件

�Cinclude-from=FILE 不排除FILE指定模式匹配的文件

�Cversion 打印版本信息

�Caddress 绑定到特定的地址

�Cconfig=FILE 指定其他的配置文件,不使用默认的rsyncd.conf文件

�Cport=PORT 指定其他的rsync服务端口

�Cblocking-io 对远程shell使用阻塞IO

-stats 给出某些文件的传输状态

�Cprogress 在传输时现实传输过程

�Clog-format=FORMAT 指定日志文件格式

�Cpassword-file=FILE 从FILE中得到密码

�Cbwlimit=KBPS 限制I/O带宽,KBytes per second

-h, �Chelp 显示帮助信息



你可能感兴趣的:(ubuntu,职场,rsync,休闲)