linux rsync配置

服务器之间常常要保持些文件或目录的一致,比如一些大的软件下载网站,它们通常使用多台服务器来提供下载服务。当一台服务器上的文件更新后,其它的服务器也需要更新,而且 在更新的时候应该是只对新增或是修改过的文件进行更新,否则会造成网络带宽和时间的浪费。rsync就是能有效的保持文件及目录的一致的优秀软件。

  rsync,remote synchronize顾名思意就知道它是一款实现远程同步功能的软件,它在同步文件的同时,可以保持原来文件的权限、时间、软硬链接等附加信息,而且可以通过ssh方式来传输文件,这样其保密性也非常好,另外它还是免费的软件。rysnc的官方网站:http://rsync.samba.org/,可以从上面得到最新的版本。当然,因为rsync是一款如此有用的软件,所以很多Linux的发行版本都将它收录在内了。你的Linux里并没有安装rsync,你可以按以下的安法自行安装:

首先到官网下载http://ftp.samba.org/ftp/rsync

2.解压

  # tar -xzpvf rsync-3.1.0.tar.gz

3.编译安装

  # cd  rsync-3.1.0/
  # ./configure
  # make
  # make install

以上过程没有出现的话就安装好了,现在就有rsync命令可以用了,rsync命令放在/usr/local/rsync/bin。用rsync命令可以去运行有rsync服务的服务器上抓取资料。

!!!!以上步骤。所有节点均需要配置,如果要把当前的机器变成一台rsync服务器的话,就需要继续进行一些配置了。

一下例子为:两台linux系统机器,192.168.153.135(做为rsync服务器)、192.168.153.136(rsync客户端)

二、配置rsync服务

1、配置rsyncd.conf文件

[root@redhat_ha1 ~]# more /etc/rsyncd.conf
secrets file = /etc/rsyncd.secret   ####密码文件
motd file = /etc/rsyncd.motd
read only = yes
list = yes
uid = nobody
gid = nobody
hosts allow = 192.168.153.136      ##客户端
hosts deny = 192.168.153.0/8       ##禁止哪个网段登录
max connections = 2
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
[terry]
comment = Terry 's directory from 192.168.153.136
path = /home/terry
auth users = root,rstest            ##主机层面要先建好rsync的涉及的帐号(次处为root和rstest用户),如果用root同步也可以
[test]
comment = test rsync
path = /home/test

2.rsyncd.secrets

# vi /etc/rsyncd.secret

  rsyncd.secret是存储rsync服务的用户名和密码的,它是一个明文的文本文件,下面给出一个rsyncd.secret文件的例子:

  terry:12345
  rsync:abcde

  因为rsyncd.secrets存储了rsync服务的用户名和密码,所以非常重要,因此文件的属性必须设为600,只有所有者可以读写:

  # chmod 600 /etc/rsyncd.secret

!!!客户端也需要配置密码文件,但是与服务端不通,客户端配置文件里没有用户名,如:

# vi /etc/rsyncd.secret

rstest

!!!!

3.rsyncd.motd

  # vi /etc/rsyncd.motd

  rsyncd.motd记录了rsync服务的欢迎信息,你可以在其中输入任何文本信息,如:

  Welcome to use the rsync services!

  4.services

  # vi /etc/services

  services并不是rsync的配置文件,这一步也可以不做。而修改了services文件的好处就在于系统知道873端口对就的服务名为rsync。修改services的方法就是确保services中有如下两行,没有的话就自行加入:

  rsync  873/tcp  # rsync
  rsync  873/udp  # rsync

5./etc/xinetd.d/rsync

  # vi /etc/xinetd.d/rsync

  建立一个名为/etc/xinetd.d/rsync文件,输入以下内容:

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

/etc/rc.d/init.d/xinetd reload  重新加载文件

  保存后,就可以运行rsync服务了。输入以下命令:

/usr/local/bin/rsync --daemon
验证启动是否成功:
netstat -na|grep 873

 三、rsync命令的用法

在两台机器上建好/home/terry目录

如果想将主服务器(192.168.153.135机器)的这个目录同步到客户端(192.168.153.136机器),需要在136机器上执行如下:

rsync -avP terry@192.168.153.135:/home/terry /home

如果设置成免输入密码,

 [root@redhat_ha2 etc]# rsync -vrtL [email protected]::terry /home --progress --password-file=/etc/rsyncd.secret
Welcome to use the rsync services!

receiving incremental file list

sent 21 bytes  received 113 bytes  89.33 bytes/sec
total size is 0  speedup is 0.00
[root@redhat_ha2 etc]#

测试有几个注意地方:

1、服务端需要进行完全配置,客户端只需要安装软件以及配置密码文件即可

2、密码文件的写法上,服务端和客户端不通

3、免密码命令里,::terry  此处的::是服务端配置rsyncd.config里[terry]配置问题

猜你喜欢

转载自andyniu.iteye.com/blog/2002169