Rsync文件同步机备份工具使用
一,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文件同步机备份工具使用的更多相关文章
- Linux基础学习-数据备份工具Rsync
数据备份工具rsync 作为一个系统管理员,数据备份是非常重要的,如果没有做好备份策略,磁盘损坏了,那么你的数据将全部丢失,所以在日常的维护工作中,一定要时刻牢记给数据做备份. rsync不仅可以可以 ...
- Linux系统备份还原工具4(rsync/远程数据同步工具)
rsync即是能备份系统也是数据同步的工具. 在Jenkins上可以使用rsync结合SSH的免密登录做数据同步和分发.这样一来可以达到部署全命令化,不需要依赖任何插件去实现. 命令参考:http:/ ...
- Linux Rsync实现文件同步备份(转载)
原文地址:Linux Rsync实现文件同步备份作者:夷北 转自:http://www.mike.org.cn/blog/index.php?load=read&id=639###pp=0 [ ...
- linux下的数据备份工具rsync讲解
linux下的数据备份工具 rsync(remote sync 远程同步) 名词解释: sync(Synchronize,即“同步”)为UNIX操作系统的标准系统调用,功能为将内核文件系统缓冲区的 ...
- Rsync数据备份工具
Rsync数据备份工具 1.Rsync基本概述 rsync是一款开源的备份工具,可以在不同主机之间进行同步(windows和Linux之间 Mac和 Linux Linux和Linux),可实现全量备 ...
- Linux下简单粗暴使用rsync实现文件同步备份【转】
这篇来说说如何安全的备份,还有一点不同的是上一篇是备份服务器拉取数据,这里要讲的是主服务器如何推送数据实现备份. 一.备份服务器配置rsync文件 vim /etc/rsyncd.conf #工作中指 ...
- rsync从linux到linux的文件同步备份
rsync从linux到linux的文件同步备份 一.环境 需要备份文件的服务器(服务器端):192.168.1.201 (RHEL 5) 接收备份文件的服务器(客户端):192.168.1.202 ...
- rsync数据同步备份
一.rsync简介 (1)rsync是什么? rsync是一款开源的.快速的.多功能的.可实现全量及增量的本地或远程数据同步备份的优秀工具. (2)rsync作用比较 远程拷贝:有点类似ssh的scp ...
- Rsync文件同步
Rsync文件同步 本章结构 关于rsync 1.一款增量备份工具,remote sync,远程同步,支持本地复制或者与其他SSH.rsync主机同步,官方网站:http://rsync.samba. ...
随机推荐
- 红米Note4X开发者选项
1.打开,设置->我的设备->全部参数 2.看到“MIUI版本”连点7次,在点击的过程中下部会有提示“在点X次就进入开发者模式”. 3.完成2步后,再次打开,设置->更多设置(系统和 ...
- Atitit.各种 数据类型 ( 树形结构,表形数据 ) 的结构与存储数据库 attilax 总结
Atitit.各种 数据类型 ( 树形结构,表形数据 ) 的结构与存储数据库 attilax 总结 1. 数据结构( 树形结构,表形数据,对象结构 ) 1 2. 编程语言中对应的数据结构 jav ...
- dataGridViewX操作
private void dataGridView1_RowStateChanged(object sender, DataGridViewRowStateChangedEventArgs e) { ...
- Java Mail(一):telnet实现发送收取邮件
http://blog.csdn.net/ghsau/article/details/8602076 ******************************* 最近要做一个解析邮件的东东,就顺便 ...
- MongoDB Replica Set搭建集群
MongoDB做集群,版本3.2官网推荐的集群方式Replica Set 准备服务器3台 两个standard节点(这两个节点直接可以互切primary secondary). 一个arbiter节点 ...
- 使用python对mysql主从进行监控,并调用钉钉发送报警信息
1.编写python的监控脚本 A.通过获取mysql库中的状态值来判断这个mysql主从状态是否正常 B.进行两个状态值的判断 C.进行调取钉钉机器人,发送消息 2.设置定时任务进行脚本运行 cro ...
- Spring整合redis,通过sentinel进行主从切换
实现功能描述: redis服务器进行Master-slaver-slaver-....主从配置,通过2台sentinel进行failOver故障转移,自动切换,采用该代码完全可以直接用于实际生产环境. ...
- java web 自定义filter
filter顾名思义,过滤器的意思,在javaweb中的Struts就利用了这种机制去实现视图和业务分离. 这里来配置下自己的Filter来理解下Struts的内在. 在web.xml 中添加下面: ...
- scala flatMap reduceLeft foldLeft
object collection_t1 { def flatMap1(): Unit = { val li = List(,,) val res = li.flatMap(x => x mat ...
- c#用picturebox显示多页TIF
//引用 using System.Drawing; using System.Drawing.Imaging; //以下是方法 private Bitmap myImage = null; priv ...