rsync+inotify实现数据同步——单向传输

实验环境:<从A主机推送数据到B主机[B主机可以有多个]>

A主机:10.1.43.102

B主机:10.1.43.103


配置流程:

—rsyncserver—- <B主机上配置>

1.vim /etc/rsyncd.conf(用户,目录,模块,虚拟用户及密码文件)

vim /etc/rsyncd.conf
uid = root
gid = root
port = 873 #post rsync使用的端口号  也是默认端口号 www.jbxue.com
hosts allow = 10.1.43.103 #allow hosts ip 应许的ip访问,也可以设置为ip段
max connections = 200  
timeout = 300
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsync.lock
log file = /var/log/rsyncd.log
    
[backup]
path =/var/www/html  #客服端已rsync服务端同步的文件路径
comment = from 10.1.43.103  #解释
read only = no
write only = no
list = no
    
auth users =rsync  #配置登陆名称
secrets file = /etc/rsync.password  #配置用户名密码文件

2.创建共享目录:/test/rsync

mkdri -pv /test/rsync

3、创建密码文件,文件路径和文件名参照配置文件里"secrets file"选项的值,然后添加密码内容

vim /etc/rsync.password
rsync:123456

4、密码文件的权限600

chmod 600 /etc/rsync.password

5、运行rsync,并且开机启动

rsync –daemon
echo "rsync –daemon" >> /etc/rc.local

6、如果出错,查看日志  

tail /var/log/rsyncd.log

——rsyncclient——<A主机上配置>

1、密码文件

vim /etc/rsync.password
123456   #注意:此处只需要写服务端虚拟帐号的密码即可

2、密码文件的权限600

chmod 600 /etc/rsync.password

3.创建共享目录:/test/rsync

mkdri -pv /test/rsync

4、安装inotify-tools软件包

yum -y install inotify-tools

5、编写同步脚本

vim /root/bin/rsync.sh
#!/bin/bash
src=/test/rsync   
des=backup       
host="10.1.43.102"  
/usr/bin/inotifywait -mrq --timefmt '%d/%m/%y%H:%M' --format '%T%w%f' -e modify,delete,create,attrib \  #此行尚未完结
$src | while read files; do
  for hostip in $host; do
    rsync -avz --delete --progress --password-file=/etc/rsync.password $src rsync@$hostip::$des
  done
  echo "${files} was rsynced" >>/tmp/rsync.log 2>&1
done

6、后台自动运行,并且开机自动启动

nohup /bin/bash /root/bin/rsync.sh &
echo "nohup /bin/bash /root/bin/rsync.sh &" >> /etc/rc.loacl

如果再配置过程中出现如下问题

问题一:

@ERROR: chroot failed

rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]

原因:

服务器端的目录不存在或无权限,创建目录并修正权限可解决问题

问题二:

@ERROR: auth failed on module backup

rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]

原因:

服务器端该模块(backup)需要验证用户名密码,但客户端没有提供正确的用户名密码,认证失败

提供正确的用户名密码解决此问题

问题三:

@ERROR: Unknown module ‘backup'

rsync error: error starting client-server protocol (code 5) at main.c(1522) [receiver=3.0.3]

原因:

服务器不存在指定模块。提供正确的模块名或在服务器端修改成你要的模块以解决问题

问题四:

password file must not beother-accessible

continuing without password file

Password:

原因:

这是因为rsyncd.pwdrsyncd.secrets的权限不对,应该设置为600。如:chmod600 rsyncd.pwd

问题五:

rsync: failed to connect to218.107.243.2: No route to host (113)

rsync error: error in socket IO(code 10) at clientserver.c(104) [receiver=2.6.9]

原因:

对方没开机、防火墙阻挡、通过的网络上有防火墙阻挡,都有可能。关闭防火墙,其实就是把tcp udp的873端口打开

问题六:

rsync error: error startingclient-server protocol (code 5) at main.c(1524) [Receiver=3.0.7]

原因:

/etc/rsyncd.conf配置文件内容有错误。请正确核对配置文件

问题七:

rsync: chown "" failed:Invalid argument (22)

原因:

权限无法复制。去掉同步权限的参数即可。(这种情况多见于Linux向Windows的时候)

 

问题八:

@ERROR: daemon security issue –contact admin

rsync error: error starting client-server protocol (code 5) at main.c(1530)[sender=3.0.6]

原因:

同步的目录里面有软连接文件,需要服务器端的/etc/rsyncd.conf打开use chroot = yes。掠过软连接文件

原创文章,作者:megedugao,如若转载,请注明出处:http://www.178linux.com/54883

(0)
megedugaomegedugao
上一篇 2016-10-27
下一篇 2016-10-27

相关推荐

  • 第二周博客作业

    1.Linux上的文件管理类命令都有那些,其常用的使用方法及其相关示例演示。
    2.Bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。
    3.请使用命令行展开功能来完成以下的练习。
    4.文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。
    5.如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?
    6.显示/var目录下所有以1开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其他字符)的文件或目录。
    7.显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
    8.显示/etc目录下,以非字母开头,后面跟了一个字母以及其他任意长度任意字符的文件或目录。
    9.在/tmp目录下创建以tgile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22
    10.复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
    11.复制/etc目录下所有以.d结尾的文件或目录到/tmp/mytest2目录中。
    12.复制/etc目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。

    2018-03-22
  • 第四周作业2

    #### 1、 复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 首先,利用cp命令将/etc/skel目录复制为/home/tuser1: “` [root@localhost ~]# cp -r /etc/skel /home/tuser1 “` 随…

    Linux干货 2018-03-24
  • Linux基础:计算机的组成及其功能

    N28 第一周作业

    2017-12-06
  • 开篇

    正式开始学习的第一天,了解LINUX,爱上LINUX。希望在往后的日子里越战越勇!!

    Linux干货 2017-07-11
  • Linux基础知识——文件查找

    Linux系统的核心思想之一就是一切皆文件,可想而知你要靠记忆去查找一个文件该是多么费劲;今天我们介绍几个文件查找命令:whereis,locate,find whereis locate the binary, source, and manual page files for…

    Linux干货 2016-10-11
  • 系统启动流程

    linux系统启动流程 内核的设计结构单内核:linux(线程–lwp轻量级进程)微内核:windows(支持真正意义上的多线程) 单内核:很多功能驱动都集成在一起 微内核:内核很小,功能单一。模块化 linux为了适应众多用户的不同硬件需求,linux内核在设计上采用模块化设计。可以动态加载模块。核心模块:ko 内核所独有的。共享对象:so 红…

    Linux干货 2016-09-19