基于rsync方式的文件备份
- rsync 是一个快速增量文件传输工具,它可以用于在同一主机备份内部的备分,我们还可以把它作为不同主机网络备份工具之用。本文主要讲述的是如何自架rsync服 务器,以实现文件传输、备份和镜像。相对tar和wget来说,rsync 也有其自身的优点,比如速度快、安全、高效;
- rsync同步模式:
sync在进行同步或备份时,使用远程shell,或TCP连接远程daemon,有两种途经连接远程主机。
shell模式,不需要使用配置文件,也不需要启动远端rsync。远程传输时一般使用ssh作为传输工具。
daemon模式,但必须在一台机器上启动rsync。
- rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件。rsync使用所谓的“rsync算法”来使本地和远程两个主机之间的文件达到同步,这个算法只传送两个文件的不同部分,而不是每次都整份传送,因此速度相当快。 rsync是一个功能非常强大的工具,其命令也有很多功能特色选项,我们下面就对它的选项一一进行分析说明。
- 特性:
- 能更新整个目录
- 有选择性的保持符号链链、硬链接、文件属于、权限、设备以及时间等;
- 对于安装来说,无任何特殊权限要求;
- 对于多个文件来说,内部流水线减少文件等待的延时;
- 能用rsh、ssh 或直接端口做为传输入端口;
- 支持匿名rsync 同步文件,是理想的镜像工具;
http://man.linuxde.net/rsync rsync命令
http://www.cnblogs.com/mchina/p/2829944.html 安装rsync可参考
http://www.ttlsa.com/web/let-infotify-rsync-fast/ 真正的inotify+rsync实时同步 彻底告别同步慢
1. 基于rsync方式,需要传输多个文件时
2.1 从本地到远端,远端的rsync服务端需要部署完成
-a 参数,相当于-rlptgoD,-r 是递归 -l 是链接文件,意思是拷贝链接文件;-p 表示保持文件原有权限;-t 保持文件原有时间;-g 保持文件原有用户组;-o 保持文件原有属主;-D 相当于块设备文件;
-v 传输时的进度等信息,和-P有点关系,自己试试。可以看文档;
-z 传输时压缩;
-P 传输进度;
--bwlimit=KBPS 限制I/O带宽,KBytes per second。
--progress 在传输时现实传输过程;
--include=PATTERN 指定不排除而需要传输的文件模式,适用于精确传输指定文件,一般于exclude搭配使用;
--exclude=PATTERN 指定排除不需要传输的文件模式,格式为需要过滤的文件或目录名称,多个文件之间用空格分隔;
--exclude-from=FILE 排除FILE中指定模式的文件,将不需要传输的文件列表写入指定的文件中,每行一个文件名称;(如果该文件在传输目录下,包括文件名本身)
- 从本地推送单个文件至rsync服务器端,backup为rsync指定的bak模块用户,密码写入/home/opsuser/rsync.pass文件中,权限必须为600,本地文件为/backup02/tc-df-2005-20160729.tar.gz,远端module为bak
rsync -avzP --bwlimit= --progress --password-file=/home/opsuser/rsync.pass /backup02/tc-df--.tar.gz backup@192.168.1.100::bak #单个文件迁移,限速3M
2.从本地推送多个文件至rsync服务器端,本地目录为/backup02/,排除exclude.list文件中指定的文件,其余文件全部传输至远端module为bak的模块对应的目录下
rsync -avzP --bwlimit= --progress --password-file=/home/opsuser/rsync.pass --exclude-from=/backup02/exclude.list /backup02/ backup@192.168.1.100::bak #批量迁移本地/backup02/目录下文件,限速3M,注意参数--exclude-from后面写入的是文件名称
注:将传输目录下不需要进行备份的文件名字写入指定的文件内(如果该文件在传输目录下,包括文件名本身)
3.备份rsync服务器端bak模块文件到本地/data/backup02目录下
rsync -avzP --bwlimit= --progress --password-file=/home/opsuser/rsync.pass backup@192.168.1.100::bak /data/backup02/ #备份rsync服务器端bak模块对应目录下面的文件至本地/data/backip02/目录下,限速3M
2. 基于ssh方式传输(需要启动ssh服务,不需要启动rsync服务)
- 基于ssh方式从远程复制到本地,由于是基于ssh方式,server端不需要运行rsync服务,且远程的传输用户为系统的真实用户,若ssh默认为22端口不需要指定传输端口,以下示例指定ssh远程端口为22222进行传输
- 从远端复制到本地
rsync -avzogP --bwlimit= --progress -e 'ssh -p 22222' opsuser@192.168.1.100:/data/server-update/tc-df--.tar.gz /export/backup #基于ssh方式单个文件迁移,多个文件可以用*代替,支持正则,限速100K
- 从本地到远端
rsync -avzP --delete --exclude=".svn" -e 'ssh -p 2222' /data/backup/ opsuser@192.168.1.100:/data/server-update/ #基于ssh方式备份整个目录,本地目录为/data/backup/,排除.svn文件
示例:
//注:server为modul名[server]
//列出rsync 服务器上的所提供的同步内容
rsync --list-only root@192.168.145.5::server
//列出目录:
rsync --list-only root@192.168.93.149::server //从服务端取数据(客户端只会增加文件);
rsync -avzP root@192.168.93.149::server rhel4home[本地目录] //从服务端取数据(使客户端的文件和服务端完全一致,会删除客户端多余的文件);
rsync -avzP --delete root@192.168.93.149::server ./ //密码从文件中读取: 注意此时的密码文件里面只需要写密码不要写用户名 和服务端的文件是不同的
rsync -avzP --delete --password-file=/etc/rsyncd.secrets root@192.168.93.149::server ./ //客户端向服务端提交文件(只需要把目录更换位置即可)
rsync -avzP --delete --password-file=/kang/sercet ./ root@192.168.93.149::server
基于rsync方式的文件备份的更多相关文章
- 一种基于Rsync算法的数据库备份方案设计
根据容灾备份系统对备份类别的要求程度,数据库备份系统可以分为数据级备份和应用级备份.数据备份是指建立一个异地的数据备份系统,该系统是对原本地系统关键应用数据实时复制.当出现故障时,可由异地数据系统迅速 ...
- 【ALB技术笔记】基于多线程方式的串行通信接口数据接收案例
基于多线程方式的串行通信接口数据接收案例 广东职业技术技术学院 欧浩源 1.案例背景 在本博客的<[CC2530入门教程-06]CC2530的ADC工作原理与应用>中实现了电压数据采集的 ...
- Shiro入门之二 --------基于注解方式的权限控制与Ehcache缓存
一 基于注解方式的权限控制 首先, 在spring配置文件applicationContext.xml中配置自动代理和切面 <!-- 8配置自动代理 --> <bean cl ...
- 基于rsync的lsyncd自动同步配置
环境部署 源机:192.168.31.140 目标机:192.168.31.130 源机配置 基于rsync的lsyncd 自动同步,rsync的配置省略 安装lsyncd rpm -ivh lsyn ...
- 技术实战:基于 MHA 方式实现 MySQL 的高可用(转)
转自:http://os.51cto.com/art/201307/401702_all.htm MHA故障转移可以很好的帮我们解决从库数据的一致性问题,同时最大化挽回故障发生后的数据.本文分享了基于 ...
- Elasticsearch-mapper 基于注解方式生成mapping(2.0以上)
Elasticsearch生成mapping的方式上有多种方式,我们可以把mapping做成配置文件,也可以用spring-data-elasticsearch基于注解生成. 在基于注解生成这种方式上 ...
- sersync基于rsync+inotify实现数据实时同步
一.环境描述 需求:服务器A与服务器B为主备服务模式,需要保持文件一致性,现采用sersync基于rsync+inotify实现数据实时同步 主服务器A:192.168.1.23 从服务器B:192. ...
- SpringMVC入门(基于注解方式实现)
---------------------siwuxie095 SpringMVC 入门(基于注解方式实现) SpringMVC ...
- SpringMVC入门(基于XML方式实现)
----------------------siwuxie095 SpringMVC 入门(基于 XML 方式实现) (一)搭建 SpringMVC 环境 1.先下载相关库文件,下载链接: (1)ht ...
随机推荐
- centos7 nginx开启启动
centos 7以上是用Systemd进行系统初始化的,Systemd 是 Linux 系统中最新的初始化系统(init),它主要的设计目标是克服 sysvinit 固有的缺点,提高系统的启动速度.关 ...
- Ajax-更新
ajax是与服务器进行(异步/同步)交互的技术之一交互就是对服务器一种访问ajax对服务器进行交互时页面不刷新ajax的语言载体是JS 比如我在百度输入个东西 自动弹出信息像和一些搜索字体相关的页面标 ...
- Android 菜单和上下文演示
在Action添加个TextView控件(上下文演示用); package com.example.test; import android.app.Activity;import android.o ...
- Linux高级编程--03.make和makfile
Makefile语法基础 在Linux下,自动化编译工具是通过make命令来完成的(一些工具厂商也提供了它们自己的make命令,如gmake等),make命令的基本格式如下: make [-f mak ...
- 读书笔记 ~ Python黑帽子 黑客与渗透测试编程之道
Python黑帽子 黑客与渗透测试编程之道 <<< 持续更新中>>> 第一章: 设置python 环境 1.python软件包管理工具安装 root@star ...
- 2017ACM暑期多校联合训练 - Team 7 1008 HDU 6127 Hard challenge (极角排序)
题目链接 Problem Description There are n points on the plane, and the ith points has a value vali, and i ...
- 使用Burpsuite爆破弱口令教工号
使用Burpsuite爆破弱口令教工号 发表于 2015-11-18 | 分类于 Burpsuite | 1条评论 | 26次阅读 准备 所谓工欲善其事,必先利其器,首先当然是要下 ...
- hdu 5328 Problem Killer(杭电多校赛第四场)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5328 题目大意:找到连续的最长的等差数列or等比数列. 解题思路:1.等差等比的性质有很多.其中比较重 ...
- php的发展历史
php最初就是为了快速构建一个web页面而迅速被大家广为接受的.它的好处是在代码中能内嵌html的代码,从而让程序员能再一个页面中同时写html代码和php代码就能生成一个web页面. 这篇文章用时间 ...
- Class类和ClassLoader类的简单介绍
反射机制中的Class Class内部到底有什么呢?看下图! 代码: Class cls=Person.class; 1.Class类: 1. 对象照镜子后可以得到的信息:某个类的数据成员名,方法和构 ...