rsync安装配置
<p>rsync,remote synchronize顾名思意就知道它是一款实现远程同步功能的软件,它在同步文件的同时,可以保持原来文件的权限、时间、软硬链接等附加信息。 rsync是用 “rsync 算法”提供了一个客户机和远程文件服务器的文件同步的快速方法,而且可以通过ssh方式来传输文件,这样其保密性也非常好,另外它还是免费的软件。这边讲讲rsync安装配置,rsync的常用操作。</p><h3>1、 准备</h3>
<p>版本:3.0.7</p>
<p>网址:http://www.samba.org/ftp/rsync/</p>
<p>下载地址:http://www.samba.org/ftp/rsync/rsync-3.0.7.tar.gz</p>
<h3>2、下载安装</h3>
<p></p><pre class="brush:bash;toolbar:false"># cd /usr/local/src/tarbag/ //切换下载目录
# wget http://www.samba.org/ftp/rsync/rsync-3.0.7.tar.gz //wget下载文件
# tar –xzvf rsync-3.0.6.tar.gz –C ../software/ //解压tar包到指定目录
# cd /usr/local/src/software/ rsync-3.0.6/ //切换到解压目录
# ./configure --prefix=/usr/local/rsync –disable-ipv6 //配置
# make && make install //编译安装</pre><p></p>
<h3><span>3、 服务器端配置</span></h3>
<p></p><pre class="brush:bash;toolbar:false"># vi rsyncd.conf
log file = /usr/local/rsync/var/rsyncd.log //日志文件
pid file = /usr/local/rsync/var/rsyncd.pid //pid文件路径
lock file = /usr/local/rsync/var/rsyncd.lock //指定lock文件
secrets file = /usr/local/rsync/etc/rsyncd.pas //指定用户密码对文件
motd file = /usr/local/rsync/etc/rsyncd.motd //指定欢迎消息文件
read only = yes //是否只读(若从客户端同步到服务器必须设置为NO)
hosts allow = 192.168.0.0/16,192.168.1.0/24 //允许的IP段
list = yes //是否允许列表
uid = nobody //rsync以什么用户身份启动
gid = nobody //rsync以什么用户组身份启动
use chroot = no //
max connections = 4 //最大连接数
//模块
path = /bak //模块目录
comment = www bak //描述信息,可以任意填写
auth users = bak //认证的用户,服务器必须存在这个系统用户
(保存退出)</pre><p>-----------以下为rsyncd.conf配置文件内容,rsync配置直接拷贝-------</p><pre class="brush:bash;toolbar:false">log file = /usr/local/rsync/var/rsyncd.log
pid file = /usr/local/rsync/var/rsyncd.pid
lock file = /usr/local/rsync/var/rsyncd.lock
secrets file = /usr/local/rsync/etc/rsyncd.pas
motd file = /usr/local/rsync/etc//rsyncd.motd
read only = yes
hosts allow = 192.168.0.0/16,192.168.1.0/24
list = yes
uid = nobody
gid = nobody
use chroot = no
max connections = 30
path = /bak
comment = www bak
auth users = root</pre><p>-----------------------------------------------------------</p><pre class="brush:bash;toolbar:false"># vi rsyncd.pas //用户密码对文件,用“:”隔开
bak:123456
(保存退出)
# chmod 600 rsyncd.pas //权限必须为600,否则会出错
# vi rsyncd.motd //配置欢迎消息
welcome to rsync 161
# rsync --daemon --config=/usr/local/rsync/etc/rsyncd.conf</pre><p></p>
<h3>3、 客户端配置</h3>
<p></p><pre class="brush:bash;toolbar:false"># vi /etc/rsyncd.pas
123456
#chmod 600 /etc/rsyncd.pas //单单密码,权限必须是600
# rsync -avH --progress --delete --password-file=/etc/rsyncd.pas /ftpdata/client/ root@192.168.50.161::bak</pre><p><span>解释:</span></p>
<p>--delete:bak模块中存在客户机不存在文件将被删除</p>
<p>--password-file:与服务器端匹配的密码文件</p>
<p>/ftpdata/client/:同步源目录</p>
<p>root@192.168.50.161::bak:同步目标模块,以及root为服务器端认证用户</p>
<p>实现功能:把本地目录/ftpdata/client/下的所有文件同步(拷贝)到192.168.50.161这台服务器上的rsync内的bak模块目录中。</p>
<h3>注意点:</h3>
<p>1、 rsync服务器端必须存在bak这个真实用户</p>
<p>2、 客户端和服务器的rsyncd.pas文件权限必须为600</p>
<p>3、 Secrets file 路径必须正确,否则日志中将会提示密码文件不存在</p>
<p>4、 Uid与Gid如果为nobody,则模块的所有者和所有组必须改为nobody</p>
<p>5、 rsyncd.pas内的密码和系统用户的密码不同,服务器为用户密码对,而客户端仅仅是密码</p>
<p>6、 服务器端rsyncd.pas内可以有多个用户密码对,客户端的rsyncd.pas只能有一个密码</p>
<p>7、 有问题查看/usr/local/rsync/var/rsyncd.log内的日志</p>
<h3>几种同步方法:</h3>
<p>Rsync –anH 本地目录 远程IP:具体目录(回车之后提示输入root密码,相当于拷贝)</p>
<p>例如:</p>
<p>Rsync –avH /usr/local/src 192.168.0.2:/bak/test/ -》把src整个目录拷到test内</p>
<p>Rsync –avH /usr/local/src/ 192.168.0.2:/bak/test/ ->把src目录内的所有文件拷贝到test内</p>
<p>Rsync –anH 远程IP:具体目录 本地目录—>远程同步到本地,需要root密码</p>
<p>Rsync –anH rsync用户@IP::模块 本地目录 -->从服务器模块同步到本地目录</p>
<p>注:配置常见问题及解决办法:http://blog.chinaunix.net/uid-26569333-id-3067813.html</p>
頁:
[1]