一,Rsync简介

Rsync是一款开源的,快速的,多功能的,可实现全量及增量的本地或远程数据同步的优秀工具。适用于多种操作平台。

全称是Remote synchronization 具有可使本地和远程的两台主机之间的数据快速复制同步镜像,这个功能类似于ssh的scp命令,但是又优于scp,rsync可以是一个网络服务(port socket)一个rsync相当于scp,cp,rm但是优于他们的每一个命令。

在同步数据时,默认情况下,rsync通过其独特的quick check算法,它仅同步大小或者最后修改时间发生变化的文件或者目录。

rsync特性

二,rsync的工作场景

1,两台服务器之间数据同步

2,对数据服务器做备份或者同步

三,rsync的工作方式

1,本地数据备份,相当于cp rm等

rsync -avz /etc/hosts /tmp/

保存属性复制文件hosts相当于cp命令

新建一个目录为空目录/null

rsync -avz --delete /null/ /tmp/

/tmp/目录保存和/null/目录一样文件全部删除了,相当于rm

2,本地局域网主机互相备份 remote shell

rsync -avzP -e 'ssh -p 22' /tmp/ root@172.16.25.32:/tmp

从本地推向远端服务器

rsync -avzP -e 'ssh -p 22' root@172.16.25.32:/tmp/ /tmp/

从远端服务器拉向本地

出现错误提示rsync error: error in IPC code因为客户端没有安装ssh客户端使用命令yum -y install openssh-clients安装即可

-e 表示后面使用ssh传输

3,通过rsync的daemon

参数-v详细输出模式

-z压缩

-a 归档模式,以递归方式传输文件,并保持所有文件属性

-r对子目录已递归模式

-t保持文件时间信息

-o保持文件属主信息

-g保持文件属组信息

-p 保持文件权限

使用最多就是avz

四,服务端安装配置rsync

1,yum安装rsync

  yum -y install rsync

2,新建配置文件

  /etc/rsyncd.conf

  

#Rsync server
#created by liuyueming : --
##rsyncd.conf start##
uid = rsync #客户端连接过来的用户
gid = rsync
use chroot = no #创建不安全文件漏洞,这里关闭
max connections = #最大连接数
timeout = #超时时间
pid file = /var/run/rsyncd.pid #进程号文件,启动后进程号
lock file = /var/run/rsync.lock #锁定文件
log file = /var/log/rsyncd.log #日志文件
ignore erros #忽略错误
read only = false #可读写
list = false #不能看服务端列表
hosts allow = 172.16.25.0/ #允许主机
hosts deny = 0.0.0.0/ #拒绝主机
auth users = rsync_backup #认证用户,为虚拟用户
secrets file = /etc/rsync.password #认证用户密码文件
################################
[backup]
comment = backup by liuyueming : -- #描述
path = /backup

3,启动

rsync --daemon

使用873端口对外进行服务

4,创建用户

useradd rsync -s /sbin/nologin -M  #不需要登录,不需要家目录

id rsync                      #检查创建用户是否成功

5,创建密码文件

echo "rsync_backup:oldboy">/etc/rsync.password

chmod 600 /etc/rsync.password #设置权限只有root可以读写  不设置成600可能会导致服务不能跑

6,可以加入开机自启动

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

五,客户端配置

1,创建本地密码文件

echo "oldboy" >/etc/rsync.password  #只需要密码,不需要用户名

chmod 600 /etc/rsync.password       #必须设置为600否则运行rsync出错

2,同步文件

本地往rsync服务器推送

rsync -avz /tmp/ rsync_backup@172.16.25.32::backup --password-file=/etc/rsync.password

#::后面的backup为服务器端配置文件/etc/rsyncd.conf里面[backup]对应

本地从rsync服务器拉去

rsync -avz rsync_backup@172.16.25.32::backup /tmp/ --password-file=/etc/rsync.password

另外一种写法

把远端文件拿回本地

rsync -avz rsync://rsync_backup@172.16.25.32/backup /tmp/ --password-file=/etc/rsync.password  #换一种写法,效果一样

重启rsync服务

pkill rsync  #关闭rsync服务

kill `cat /var/run/rsyncd.pid`

kill -HUP `cat /var/run/rsyncd.pid`  #加参数平滑杀进程

kill -USR2 `cat /var/run/rsyncd.pid`  #加参数平滑杀进程

六,rsync优点

1,增量备份同步,正常socket(daemon模式),集中备份。最好采用推送而不是抓取方式

七,rsync缺点

1,大量小文件同步的时候,比对时间比较长,有时候会导致rsync进程停止

解决办法:a,打包同步b,drbd(基于文件系统同步复制block)

2,同步大文件,10G这样的大文件有时也会有问题,中断。未完整同步前,是隐藏文件,同步完成为正常文件。

PS:可以启用定时任务实现实时同步,定时任务最小间隔为1分钟,如果需要完全是实时同步需要使用inotify等技术。

Rsync文件同步机备份工具使用的更多相关文章

  1. Linux基础学习-数据备份工具Rsync

    数据备份工具rsync 作为一个系统管理员,数据备份是非常重要的,如果没有做好备份策略,磁盘损坏了,那么你的数据将全部丢失,所以在日常的维护工作中,一定要时刻牢记给数据做备份. rsync不仅可以可以 ...

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

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

  3. Linux Rsync实现文件同步备份(转载)

    原文地址:Linux Rsync实现文件同步备份作者:夷北 转自:http://www.mike.org.cn/blog/index.php?load=read&id=639###pp=0 [ ...

  4. linux下的数据备份工具rsync讲解

    linux下的数据备份工具 rsync(remote sync 远程同步)   名词解释: sync(Synchronize,即“同步”)为UNIX操作系统的标准系统调用,功能为将内核文件系统缓冲区的 ...

  5. Rsync数据备份工具

    Rsync数据备份工具 1.Rsync基本概述 rsync是一款开源的备份工具,可以在不同主机之间进行同步(windows和Linux之间 Mac和 Linux Linux和Linux),可实现全量备 ...

  6. Linux下简单粗暴使用rsync实现文件同步备份【转】

    这篇来说说如何安全的备份,还有一点不同的是上一篇是备份服务器拉取数据,这里要讲的是主服务器如何推送数据实现备份. 一.备份服务器配置rsync文件 vim /etc/rsyncd.conf #工作中指 ...

  7. rsync从linux到linux的文件同步备份

    rsync从linux到linux的文件同步备份 一.环境 需要备份文件的服务器(服务器端):192.168.1.201 (RHEL 5) 接收备份文件的服务器(客户端):192.168.1.202 ...

  8. rsync数据同步备份

    一.rsync简介 (1)rsync是什么? rsync是一款开源的.快速的.多功能的.可实现全量及增量的本地或远程数据同步备份的优秀工具. (2)rsync作用比较 远程拷贝:有点类似ssh的scp ...

  9. Rsync文件同步

    Rsync文件同步 本章结构 关于rsync 1.一款增量备份工具,remote sync,远程同步,支持本地复制或者与其他SSH.rsync主机同步,官方网站:http://rsync.samba. ...

随机推荐

  1. 字符串函数---itoa()函数具体解释及实现

    itoa()函数 itoa():char *itoa( int value, char *string,int radix); 原型说明: value:欲转换的数据. string:目标字符串的地址. ...

  2. [svc]C10K 问题引发的技术变革

    C10K 问题引发的技术变革 http://rango.swoole.com/archives/381 C10K 问题 服务器应用领域很古老很出名的一个问题,大意是说单台服务器要同时支持并发 10K ...

  3. po vo

    一.PO:persistant object 持久对象,可以看成是与数据库中的表相映射的java对象.使用Hibernate来生成PO是不错的选择. 二.VO:value object值对象.通常用于 ...

  4. 找电影资源最强攻略,知道这些你就牛B了!

    找电影资源最强攻略,知道这些你就牛B了! 电影工厂 2015-07-01 · 分享   点击题目下方环球电影,关注中国顶尖电影微杂志 我们也许没有机会去走遍千山万水,却可以通过电影进入各种各样的角色来 ...

  5. 页面跳转时候拼接在url后面的多个 参数获取

    function GetRequest() { var url = location.search; var theRequest = new Object(); if (url.indexOf(&q ...

  6. js 開始时间,当前时间,结束时间的比較

    //開始时间不能小于当前时间 function startTimeIsBigThanTotay(startTime){ var startdate = new Date((startTime).rep ...

  7. Tiny4412 虚拟机交叉编译环境的设置以及编译u-boot 和 kernel

    从CD 里面拷贝如下文件到虚拟机里面 解压 查看是否有如下文件 tiny4412_qt@chenfl:~/tiny4412$ ls opt/FriendlyARM/toolschain/4.5.1/b ...

  8. saveFileDialog对话框

    private void button1_Click(object sender, EventArgs e) { saveFileDialog1.Filter = "*.txt|*.txt| ...

  9. rp2836 网卡以及串口与接插件位置关系

    P3     ETH1 P6     ETH0 P7     /dev/ttyS3 调试口 P13-1  /dev/ttyS2  rs485+ P13-2  /dev/ttyS2  rs485- P1 ...

  10. 16C554在LINUX上的移植(AT91)

    16C554在LINUX上的移植(AT91) linux版本:3.14.17 AT91SAMa5d36   EINTA_0   ARM-IO5        PA14         14 EINTA ...