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秒延时
不建议采用大文件进行同步