rsync , rsync + ssh, rsync + lsyncd 多种同步方案与比较

1. 利用 ssh+rsync 
只需要在服务器端打开 ssh 服务, 并启动 xinetd 中 rsync 服务则可使用 
a. 增量同步 
  rsync -av /src-dir/.  user@ipadress:/dest-dir/
b. 镜像同步 
  rsync -av --delete /src-dir/.  user@ipadress:/dest-dir/
特点: 配置简单, 不需要配置 rsyncd.conf 配置文件, 但需要在同步过程中进行用户认证 
注: 利用 expact + gzipexe 可以创建自动同步加密脚本 
使用: 可手动同步或每天晚上定制时间任务同步 
缺点:无法实现实时同步, 不可以成为双机热备份方案么

2. 启用 rsync 服务 
需要配置 /etc/rsyncd.conf 配置文件, 需要启动 xinetd 中 rsync 服务, 可以不通过 sshd 协调 
a. 配置文件 (参考  man 5 rsyncd.conf , 目录共享管理参考 smb.conf)

rsyncd.conf 参考 
motd file = true     # 时间记录 
pid file = /var/run/rsyncd.pid 
port = 873 
address = 0.0.0.0 
log file = /var/log/rsyncd.log  # rsync 独立日志, 记录每个文件更新信息 
syslog facility = syslog   # 增加同步启动与结束信息到 /var/log/messages 仲 
uid = nobody      # 注: 定义同步时 rsync 进程用户 id 
gid = nobody 
use chroot = no

[share] 
path=/tmp/test 
read only=false

rsyncd.conf 配置安全信息: 
charset 用于设定字符集, 可用字符集参考 smb.conf 标准 
max connections 并发连接数量 
read only  读写控制 
write only 读写控制 
list  是否允许客户端利用  rsync --list-only rsync://192.168.1.11:873 查询共享目录信息 
注: rsync --list-only rsync://192.168.1.11:873/share/. 能够列出文件信息, 与 list 参数无关 
exclude 同步过程中忽略某个文件或目录 ex: = new/ old/ kdump.conf (注:只需要相对路径) 
exclude from = /etc/rsyncd.list 以文件记录同步过程忽略信息 
incoming chmod 文件目录权限定义 
outgoing chmod 文件目录权限定义 
auth users 配合 secrets file 使用, 定义用户认证(明文) = user1 user2 user3 
secrets file = filepath 验证文件 语法 user:password (必须包含上述user123) 文件 root 600 属性 
hosts allow 主机 IP 定义 
hosts deny 主机 IP 定义 
log format 默认格式 %o %h [%a] %m (%u) %f %l 参考 rsyncd.conf

常见同步语法 
rsync --list-only rsync://192.168.1.11:873/share/. 能够列出文件信息 
rsync --list-only rsync://192.168.1.11:873 查询共享目录信息 
rsync --exclude-from=file.txt rsync://192.168.1.11:873/share/.  /tmp/test/. 不同步指定信息

优点: 避免显示主机文件信息绝对路径, 多种安全设定, 不需要利用ssh 进行用户验证, 支持匿名同步 
缺点: 无法主动推送文件

3. rsync+lsyncd 数据同步

       [rsync server ]  <------     [ lsyncd ]    --->  [ rsync server ]

rsync 客户端需要编译 lsyncd 软件,安装 rsync 工具 
rsync 服务器需要配置并启动 rsync 进程, 如上例子, 匿名共享 share 目录

下载最新版 
http://lsyncd.googlecode.com/files/lsyncd-2.0.5.tar.gz 
依赖: lua >= 5.1.3, rhel6 补丁 
ftp://ftp.pbone.net/mirror/ftp.scientificlinux.org/linux/scientific/6rolling/i386/os/Packages/lua-devel-5.1.4-4.1.el6.i686.rpm

语法需调用 LUA 格式

创建配置文件 share.lua

settings = {  
.. 略 
nodaemon   = true,    # false 成为前台进程, 方便测试 
statusInterval = 3,    # lsyncd.status 状态更新时间间隔 
...略 
}

sync{ 
..  略 
}

bash = {     
... 略 
}

settings 为主配置, sync 为同步配置, bash 为同步方案

启动方法 
lsyncd  share.lua

初次启动则会自动同步文件内容, 后发生文件修改, 增加, 删除都会进行自动同步 
如果需要对多台电脑进行同步, 可以利用 lsyncd  backup.lua 等脚本多次进行进程启动

方案优点: 
  1. 自动对目录中文件向 rsync 服务器进行推送 
  2. 能够支持多台 rsync 服务器 
  3. 避免人工参与修改 
缺点: 
  同步时间非实时, 约莫具有30秒延时 
  不建议采用大文件进行同步



本文转自    geekwolf   51CTO博客,原文链接:http://blog.51cto.com/linuxgeek/997898

上一篇:基于阿里云平台进行游戏数据分析(三)


下一篇:研发效能提升 36 计第三课:束水攻沙,持续加快产品交付速度