CentOS系统rsync文件同步 安装配置

rsync是类unix系统下的数据镜像备份工具,从软件的命名上就能够看出来了——remote sync

它的特性以下:
  能够镜像保存整个目录树和文件系统。
  能够很容易作到保持原来文件的权限、时间、软硬连接等等。
  无须特殊权限便可安装。
  快速:第一次同步时 rsync 会复制所有内容,但在下一次只传输修改过的文件。rsync 在传输数据的过程当中能够实行压缩及解压缩操做,所以可使用更少的带宽。
  安全:可使用scp、ssh等方式来传输文件,固然也能够经过直接的socket链接。
  支持匿名传输,以方便进行网站镜象。


1、服务器端配置:
# yum -y install xinetdshell

# vi /etc/xinetd.d/rsync
将以下代码数据库

复制代码 代码以下:

service rsync
{
disable = yes
socket_type = stream
wait = no
user = root
server = /usr/bin/rsync
server_args = –daemon
log_on_failure += USERID
}


中的 disable = yes 改为 disable = no

而后启动 xinetd
# /etc/init.d/xinetd start 或 service xinetd restart
注意:若是服务器上装有防火墙记得要打开端口,默认端口是873安全

# telnet 127.0.0.1 873
Trying 127.0.0.1...
telnet: connect to address 127.0.0.1: Connection refused
# iptables -A INPUT -s 192.168.0.0/255.255.255.0 -p tcp -m tcp --dport 873 -j ACCEPT
# iptables -A INPUT -p tcp -m tcp --dport 873 -j DROP

# vi /etc/rsyncd.conf (这个文件若是不存在本身建立)
服务器

#Global Settings
uid = root #以什么身份运行rsync
gid = root
use chroot = no #不使用chroot
max connections = 20 #最大链接数
secrets file = /etc/rsyncd.secrets #密码文件位置,认证文件设置,设置用户名和密码
log file = /var/log/rsyncd.log #指定rsync的日志文件,而不将日志发送给syslog
pid file = /var/run/rsyncd.pid #指定rsync的pid文件
lock file = /var/run/rsync.lock #指定支持max connections参数的锁文件,默认值是/var/run/rsyncd.lock
comment = hello world
#motd file = /etc/rsyncd.motd #欢迎信息文件名称和存放位置(此文件没有,能够自行添加)

[backup] # 这里是认证的模块名,在client端须要指定
path = /titan24/www/repos # 须要作镜像的目录
auth users = rsync # 受权账号。认证的用户名,若是没有这行,则代表是匿名,多个用户用,分隔
read only = no # yes只读 值为NO意思为可读可写模式,数据恢复用NO
hosts allow = 192.168.3.128 #容许访问的服务器IP
hosts deny = * #黑名单
list = true # 容许列文件
#ignore errors # 能够忽略一些无关的IO错误
#exclude = cache/111/ cache/222/ #忽略的目录

# vi /etc/rsyncd.secrets (设置访问(认证)的用户名密码)
ssh

rsync:111111 #用户名:密碼

给文件正确的权限
# chown root:root /etc/rsyncd.secrets
# chmod 600 /etc/rsyncd.secrets  #(必须是600)
异步

2、client 端进行同步

客户端默认好像已经装了rsync,没有的话装下:
# yum -y install rsyncsocket

执行异步同步操做:tcp

/usr/bin/rsync -avz --progress  rsync@192.168.3.191::backup  /www工具

# crontab -e #(能够定时每三分钟同步一次文件)网站

*/3  * * * * rsync -avz --progress  rsync@192.168.3.191::backup  /www

下面这个命令完整一点:

#vi /etc/rsyncd.pas
加入密码
rsyncofpass
注意,客户端的密码文件只须要密码,而不须要用户名!

更改文件权限:
#chmod 0600 /etc/rsyncd.pas

#rsync -vzrtopgu --progress --delete --password-file=/etc/rsyncd.pas   rsync_user@192.168.0.2::rsync_module_name1 /www/

这个命令行中-vzrtopg里的v是verbose,
z是压缩传输,
r是recursive,
topg都是保持文件原有属性如属主、时间的参数。
u是只同步已经更新的文件,避免没有更新的文件被重复更新一次,不过要注意二者机器的时钟的同步。
–progress是指显示出详细的进度状况,
–delete是指若是服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。
后 面的rsync_user@192.168.0.2::rsync_module_name1中,以后的rsync_module_name1是模块名, 也就是在/etc/rsyncd.conf中自定义的名称,rsync_user是指定模块中指定的能够同步的用户名。
最后的/www是备份到本地的目录名。
在这里面,还能够用-e ssh的参数创建起加密的链接。
能够用–password-file=/password/path/file来指定密码文件,这样就能够在脚本中使用而无需交互式地输入验证密码了,这里须要注意的是这份密码文件权限属性要设得只有属主可读。

#/usr/local/rsync/bin/rsync -vzrtopg –progress –delete rsync_user@192.168.0.2::rsync_module_name1 /tmp/
Password:
或者你也能够制定password文件
因为须要系统crontab执行,因此这里采用读入密码文件的方式,
这个时候就成功了。

同步命令说明: 1 显示目录内容 命令 —— a) rsync b) rsync -r c) rsync jack@192.168.0.1:: d) rsync ssh_user@192.168.0.1: 命令说明 ——— a) 显示目录内容(第一层) b) 递归显示目录内容 c) 显示远程主机目录内容 *注1:端口模式, 基于rsync用户的身份验证 *注2:rsync server上的目录必须具备xx7的权限. d) 查看远程主机目录内容 *注1:remote shell模式, 经过ssh链接的基于系统本地用户的身份验证 *注2:这里只使用了一个冒号(:),同时用户名是远程主机的ssh 用户,密码也是ssh用户对应的密码。 *注3:使用””,则列出文件夹自己的信息。若要列出文件夹内容,应使用”/”。 参数说明 ——— -r 对目录进行递归操做 2 本地目录之间同步 命令 —— a) rsync -av –progress / *** 注意(/) *** b) rsync -av –progress c) rsync -avu –progress –delete / d) rsync -av –progress –temp-dir=/tmp / 命令说明 ——— a) 同步src-dir目录下全部文件到dst-dir目录下 b) 同步src-dir目录下全部文件到dst-dir/src-dir目录下 c) 对src-dir目录内容向dst-dir目录下进行差别更新,有增长/更新则添加替换,有减小则对其删减 d) 比a)多了–temp-dir=/tmp,即指定/tmp为临时交换区,这样能够避免因目标目录空间不够引发的没法同步文件的错误。 参数说明 ——— -a 至关于 -rlptgoD 的集合 -u 等同于 –update,在目标文件比源文件新的状况下不更新 -v 显示同步的文件 –progress 显示文件同步时的百分比进度、传输速率 –delete 删除目标目录中多于源目录的文件 3 异地主机之间同步 命令 —— a) rsync -avz –progress jack@192.168.0.1::/ b) rsync -avz –progress jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack c) rsync -avuz –progress –delete jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack d) rsync -avz –progress jack@192.168.0.1::/ 命令说明 ——— a) 同步本地目录的内容到远程主机192.168.0.1的目录下,jack是rsync数据库用户(参见3. /etc/rsync.secrets) b) 经过自动读取用户密码而实现非交互登陆文件同步 c) 较b)多了-u和–delete d) 同步远程主机内容到本地目录

相关文章
相关标签/搜索