希望两台机器指定目录的数据保持一致

192.168.19.252(master)                 192.168.19.251(slave)

/cache

拉复制            推复制

rsync的工作模式

C/S    client/server

B/S    browse/server

拉复制

从服务器定期去主服务器获取数据

crontab+rsync

工作过程

1   从服务器发起连接                   ip  port

2   主服务器                           固定ip  开放port(开服务)

3   需要授权                           user password

制作rsync服务

服务器端:

1、编辑配置文件

mkdir /etc/rsyncd

vim /etc/rsyncd/rsyncd.conf

uid=root

gid=root

port=873

max connections=0

log file=/var/log/rsyncd.log

pid file=/var/run/rsyncd.pid

lock file=/var/run/rsyncd.lock

motd file=/etc/rsyncd/rsyncd.motd

read only=yes

hosts allow=192.168.19.0/24

hosts deny=*

[www]

path=/cache

list=yes

ignore errors

auth users=danny

secrets file=/etc/rsyncd/rsyncd.secrets

##如果没有生成日志文件,加上下面几行

transfer logging=yes

log format=%t %a %m %f %b

syslog facility=local3

2、创建所需文件

1)欢迎页面

Vim /etc/rsyncd/rsyncd.motd

###########

##welcome##

###########

2)创建共享目录

Mkdir /cache

3)创建密码文件并修改其权限(否则客户端无法完成验证)

vim /etc/rsyncd/rsyncd.secrets

chmod 600 /etc/rsyncd/rsyncd.secrets

danny:123456

3、启动rsync服务

rsync --daemon --config=/etc/rsyncd/rsyncd.conf

4、查看服务有没有运行

lsof -i:873

客户端操作:

1、创建接收目录

Mkdir  /cache

2、拉取数据:

语法:rsync –avzP –delete –password-file=/path/filename username@Server::共享资源名称 /cache

rsync -avzP --delete --password-file=/etc/rsyncd.pw danny@192.168.19.252::www /cache

-a参数,相当于-rlptgoD,-r 是递归 -l 是链接文件,意思是拷贝链接文件;-p 表示保持文件原有权限;-t 保持文件原有时间;-g 保持文件原有用户组;-o 保持文件原有属主;-D 相当于块设备文件

-z,传输时压缩

-P,传输进度,782448  “63%  110.64kB/s    0:00:04”

-v,传输时显示传输的文件名及其简要信息

--delete  在目标文件中删除额外的文件。

这里需要注意别忘了去创建密码文件并修改权限(必须设为600)

Vim /etc/rsyncd.pw

123456

Chmod 600 /etc/rsyncd.pw

3、结合crontab定时拉取数据

Crontab –e

* * * * * rsync -avzP --delete --password-file=/etc/rsyncd.pw danny@192.168.19.252::www /cache

配置过程中容易发生的错误:

服务器和客户端的密码文件没有被设置为600

拉复制的特点:

服务器端定义共享什么目录、共享资源名、认证用户、认证密码等

客户端定义间隔多长时间拉取服务器指定目录的数据,如果间隔时间为毫秒级时,同步小文件没有问题,但同步大文件时可能会造成数据不一致,且两端系统资源的消耗可能会比较大。

说明rsync在毫秒级同步时传输大文件会导致数据不一致的情况:

1、客户端编辑脚本如下:

Vim pull.sh

#!/bin/bash

While :

Do

Rsync –avzP –delete –password-file=/etc/rsyncd.pw cjk@192.168.19.252::www /cache

Sleep 0.001  #太快了,可以改为0.01

Done

2、给脚本加执行权限

3、结合周期性计划任务执行脚本

4、在服务器端/cache目录中使用dd创建一个2G的大文件

5、文件传输后通过md5sum filename对比两文件的MD5值,会发现不同

推复制

监测到指定目录数据变化,即同步给远程主机。

配置:

本机安装配置监测软件;远程主机上配置rsync服务。

实验环境:rhel6.7

目的:监测到19.252上/cache目录发生变化后同步给19.251的/cache目录

操作:

192.168.19.252上:(服务器端)

1、将配置文件远程拷贝到19.251上(推复制本机不需要配置rsync服务,只需要一个密码文件即可)

Scp  -r /etc/rsyncd root@192.168.19.251:/etc/

2、解压监测软件

Tar –xf sersync…..tar –C /usr/src

解压之后有两个文件,confxml.xml(配置文件)和sersync2(执行文件)

3、配置检测软件的配置文件:

<sersync>

<localpath watch="/cache">

<remote ip="192.168.19.251" name="www"/>

<!--<remote ip="192.168.8.39" name="tongbu"/>-->

<!--<remote ip="192.168.8.40" name="tongbu"/>-->

</localpath>

<rsync>

<commonParams params="-artuz"/>

<auth start="true" users="danny" passwordfile="/etc/rsyncd.pw"/>

<userDefinedPort start="false" port="874"/><!-- port=874 -->

<timeout start="false" time="100"/><!-- timeout=100 -->

<ssh start="false"/>

</rsync>

4、创建配置文件中指定的密码文件,并将权限修改为600  

vim /etc/rsyncd.pw

123456

chmod 600 /etc/rsyncd.pw

5、运行检测软件

cd /usr/src/GUN-linux-x86

./sersync2 –r &    ##-r可以看到启动过程,第一次启动时将被监控目录所有数据整体同步到rsync server上

192.168.19.251上:(客户端)

1、删除原先本机上存在的密码文件:

Rm –fr /etc/rsyncd.pw

2、修改rsync配置文件(仅一行):

Read only=no  开放可写的权限

3、保证已存在/cache目录

mkdir –p /cache

4、保证密码文件权限是600

chmod 600 /etc/rsyncd/rsyncd.secrets

5、运行rsync服务

rsync –daemon –config=/etc/rsyncd/rsyncd.conf

测试:

在252上的/cache目录中创建大文件,并生成md5校验码,251上会通不过去且MD5码相同

在252上的/cache目录中创建1000个小文件,会发现251上同步的比较慢

在对rsync服务器配置结束以后,下一步就需要在客户端发出rsync命令来实现将服务器端的文件备份到客户端来。rsync是一个功能非常强大的工具,其命令也有很多功能特色选项,我们下面就对它的选项一一进行分析说明。

Rsync的命令格式可以为以下六种

  rsync [OPTION]... SRC DEST

  rsync [OPTION]... SRC [USER@]HOST:DEST

  rsync [OPTION]... [USER@]HOST:SRC DEST

  rsync [OPTION]... [USER@]HOST::SRC DEST

  rsync [OPTION]... SRC [USER@]HOST::DEST

  rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]

  

对应于以上六种命令格式,rsync有六种不同的工作模式:

  1)拷贝本地文件。当SRC和DES路径信息都不包含有单个冒号":"分隔符时就启动这种工作模式。如:rsync -a /data /backup

  2)使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。当DST路径地址包含单个冒号":"分隔符时启动该模式。如:rsync -avz *.c foo:src

  3)使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。当SRC地址路径包含单个冒号":"分隔符时启动该模式。如:rsync -avz foo:src/bar /data

  4)从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含"::"分隔符时启动该模式。如:rsync -av root@172.16.78.192::www /databack

  5)从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含"::"分隔符时启动该模式。如:rsync -av /databack root@172.16.78.192::www

  6)列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。如:rsync -v rsync://172.16.78.192/www

rsync实现数据同步的更多相关文章

  1. sersync+rsync实时数据同步

    sersync+rsync实时数据同步 1.相关背景介绍 前面有关文章配置实现了rsync增量同步以及配置为定时同步,但是在实际生产环境中需要实时的监控数据从而进行同步(不间断同步),可以采取inot ...

  2. 【linux运维】rsync+inotify与sersync+rsync实时数据同步笔记

    Rsync(remote sync)远程同步工具,通过rsync可以实现对远程服务器数据的增量备份通过,但rsync自身也有缺陷,同步数据时,rsync采用核心算法对远程服务器的目标文件进行对比,只进 ...

  3. sersync+rsync进行数据同步

    一:环境 操作系统环境:redhat6.6 内核版本:2.6.32-358.el6.x86_64 rsync server:192.168.2.3(部署rsync server) rsync clie ...

  4. Linux系统备份还原工具4(rsync/远程数据同步工具)

    rsync即是能备份系统也是数据同步的工具. 在Jenkins上可以使用rsync结合SSH的免密登录做数据同步和分发.这样一来可以达到部署全命令化,不需要依赖任何插件去实现. 命令参考:http:/ ...

  5. rsync 远程数据同步工具详解

    rysnc 命令用法:(OPTION-参数,USER-用户,HOST-IP地址,SRC-复制源位置,DEST-复制目标位置)Shell拉:rsync [OPTION] [USER@]HOST:SRC ...

  6. linux之rsync远程数据同步备份

    rsync服务是一种高效的远程数据备份的工具,该服务的port号为873, 是Liunx下的一种非独立服务.由xinetd超级服务管理,取代监听873port. 长处: 1.rsync能够利用ssh和 ...

  7. 归档 SCP SFTP RSYNC(数据同步)

    tar 选项  目标文件  源文件(1 2 3) tar cf **.tar file1 file2 file3 (默认情况下 cf选项只有归档没有压缩) tar xf 从归档中提取 创建tar的存档 ...

  8. Rsync+sersync 数据同步指南

    (1):sersync 可以记录下被监听目录中发生变化的(包括增加.删除.修改)具体某一个文件或 某一个目录的名字: (2):rsync 在同步的时候,只同步发生变化的这个文件或者这个目录(每次发生变 ...

  9. Rsync+inotify 数据同步应用指南

    Rsync+Inotify-tools (1):Inotify-tools 只能记录下被监听的目录发生了变化(包括增加.删除.修改),并没有 把具体是哪个文件或者哪个目录发生了变化记录下来: (2): ...

随机推荐

  1. linux shell脚本调用java main方法 代码传值

    #!/bin/bash #description: ljdjService export PRG_HOME=/ainmc/work/toptea/dataTransfer PRG_KEYWORD=pr ...

  2. CentOS6.9 安装Oracle 11G 版本11.2.0.1.0

    安装实例与数据库 CentOS6.9 安装Oracle 11G 版本11.2.0.1.0 一.检查系统类别. 查看 系统的类别,这里是 64位系统:[root@localhost ~]# uname ...

  3. rsync实现数据备份

    rsync实现数据备份 1.简介 rsync(remote synchronization)是一款开源的,快速的,多功能的,可实现全量和增量的的本地或远程数据同步备份的优秀工具. 2.功能 scp.c ...

  4. 如何在Qt Creator中添加库文件和头文件目录

    在使用QtCreator开发图像处理程序的时候想加入Opencv库来处理图形,添加头文件,需要编辑工程文件夹下的.pro文件在文件中添加以下内容,即可包含头文件的文件夹: INCLUDEPATH += ...

  5. 避免for循环

    http://www.360doc.com/content/10/0610/22/1217721_32411251.shtml 避免使用for循环: 在Matlab中,for循环运算效率非常低,因为M ...

  6. Android学习之Button按钮在程序运行时全部变大写的处理

    问题: 在layout布局文件中,我们命名的按钮名称是“button1”,程序运行过后,在app上显示出来的是“BUTTON1”,先看源代码和效果: 按钮源代码: 运行效果: 解决办法: 方法一: 在 ...

  7. 开发板测试-GPRS

    注意事项: 经过测试,为了使STM32和Air202的串口稳定通信,需要更改 以前电路感觉应该是三极管控制极4.7K电阻太大,又因为开关速度快,然后开关的时候导致不足以让三极管处于全部导通状态,所以电 ...

  8. python wsgi 简介

    wsgi全称是"Web Server Gateway Interfacfe",web服务器网关接口,wsgi在python2.5中加入,是web服务器和web应用的标准接口,任何实 ...

  9. Luogu4423 BJWC2011 最小三角形 平面最近点对

    传送门 题意:给出$N$个点,求其中周长最小的三角形(共线的也计算在内).$N \leq 2 \times 10^5$ 这道题唤起了我对平面最近点对的依稀记忆 考虑平面最近点对的分治,将分界线两边的求 ...

  10. 一次永久解决cmd窗口汉字显示乱码

    对于编译出的程序,在 cmd 和 power shell 运行时都不能正确显示汉字. 网上查,可以再命令窗口修改: 1.打开CMD.exe命令行窗口 2.通过 chcp命令改变代码页,UTF-8的代码 ...