zl程序教程

您现在的位置是:首页 >  其他

当前栏目

Centosrsync文件同步配置步骤分享

文件同步配置 步骤 分享
2023-06-13 09:14:35 时间

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

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


一、服务器端配置:
#yum-yinstallxinetd

#vi/etc/xinetd.d/rsync
将如下代码

复制代码代码如下:

servicersync
{
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/xinetdstart或servicexinetdrestart
注意:如果服务器上装有防火墙记得要打开端口,默认端口是873

#telnet127.0.0.1873
Trying127.0.0.1...
telnet:connecttoaddress127.0.0.1:Connectionrefused
#iptables-AINPUT-s192.168.0.0/255.255.255.0-ptcp-mtcp--dport873-jACCEPT
#iptables-AINPUT-ptcp-mtcp--dport873-jDROP

#vi/etc/rsyncd.conf(这个文件如果不存在自己创建)

#GlobalSettings
uid=root#以什么身份运行rsync
gid=root
usechroot=no#不使用chroot
maxconnections=20#最大连接数
secretsfile=/etc/rsyncd.secrets#密码文件位置,认证文件设置,设置用户名和密码
logfile=/var/log/rsyncd.log#指定rsync的日志文件,而不将日志发送给syslog
pidfile=/var/run/rsyncd.pid#指定rsync的pid文件
lockfile=/var/run/rsync.lock#指定支持maxconnections参数的锁文件,默认值是/var/run/rsyncd.lock
comment=helloworld
#motdfile=/etc/rsyncd.motd#欢迎信息文件名称和存放位置(此文件没有,可以自行添加)

[backup]#这里是认证的模块名,在client端需要指定
path=/titan24/www/repos#需要做镜像的目录
authusers=rsync#授权帐号。认证的用户名,如果没有这行,则表明是匿名,多个用户用,分隔
readonly=no#yes只读值为NO意思为可读可写模式,数据恢复用NO
hostsallow=192.168.3.128#允许访问的服务器IP
hostsdeny=*#黑名单
list=true#允许列文件
#ignoreerrors#可以忽略一些无关的IO错误
#exclude=cache/111/cache/222/#忽略的目录

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

rsync:111111#用户名:密?

给文件正确的权限
#chownroot:root/etc/rsyncd.secrets
#chmod600/etc/rsyncd.secrets #(必须是600)

二、client端进行同步

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

执行异步同步操作:

/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
注意,客户端的密码文件只需要密码,而不需要用户名!

更改文件权限:
#chmod0600/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是备份到本地的目录名。
在这里面,还可以用-essh的参数建立起加密的连接。
可以用?password-file=/password/path/file来指定密码文件,这样就可以在脚本中使用而无需交互式地输入验证密码了,这里需要注意的是这份密码文件权限属性要设得只有属主可读。

#/usr/local/rsync/bin/rsync-vzrtopg?progress?deletersync_user@192.168.0.2::rsync_module_name1/tmp/
Password:
或者你也可以制定password文件
由于需要系统crontab执行,所以这里采用读入密码文件的方式,
这个时候就成功了。

同步命令说明:

1显示目录内容

命令
——
a)rsync
b)rsync-r
c)rsyncjack@192.168.0.1::
d)rsyncssh_user@192.168.0.1:

命令说明
———
a)显示目录内容(第一层)
b)递归显示目录内容
c)显示远程主机目录内容
*注1:端口模式,基于rsync用户的身份验证
*注2:rsyncserver上的目录必须具有xx7的权限.

d)查看远程主机目录内容
*注1:remoteshell模式,通过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?progressjack@192.168.0.1::/
b)rsync-avz?progressjack@192.168.0.1::/?password-file=/home/jack/rsync.jack
c)rsync-avuz?progress?deletejack@192.168.0.1::/?password-file=/home/jack/rsync.jack
d)rsync-avz?progressjack@192.168.0.1::/

命令说明
———
a)同步本地目录的内容到远程主机192.168.0.1的目录下,jack是rsync数据库用户(参见3./etc/rsync.secrets)
b)通过自动读取用户密码而实现非交互登录文件同步
c)较b)多了-u和?delete
d)同步远程主机内容到本地目录