rsync工具
一、介绍
1、可以实现 本地数据 《----------》 远程数据/本地数据  的传输
2、两种通信方式(man rsync)
 (1)remote shell(一个冒号:),通过sshd协议传输
 (2)daemon (两个冒号 :: ) ,服务端开启一个守护进程demo并启动 rsync 服务,监听端口让客户端去连
:: 后面是模块名字,不是机器上的绝对路径
 
3、rsync 与 scp
 (1)都可以把本机数据拷贝到远程,把远程数据拷贝到本地,也支持本地到本地;支持网络通信
 (2)rsync支持增量备份,增量拷贝,节省带宽和时间
即不会把之前拷贝到远程机器,但没有改动的数据覆盖,而是只把后来变动的部分拷贝过去
 
 
二、参数说明
rsync -avL
1、-a 《===》 rlptgoD
  -r:同步目录
  -l:软链接     (-L:拷贝软链接的源文件)
  -p:权限
  -t:时间
  -g、o:属主属组
  -D:设备文件
2、-v:可视化
3、--delete:删除一致同步
4、--exclude:过滤。同步排除某些文件或目录
5、-u:如果目标文件比源文件还新,那么忽略该文件
6、-P:看同步状态、进度
 
 
三、 rsync两种工作模式
实现 本机 <--------> 远程 数据传输
机器一 : windysai   192.168.37.128   
机器二 :  sai       192.168.37.131      
 
【a】一般模式(复制) 走22端口,ssh协议   ——》假设128是本地机器,131是远程机器
1、推送数据(push)
(1)rsync -avPz    local/     192.168.37.131:/root/remote
 
2、拉取数据(pull)
(1)远程机器: 远程目录 本地
rsync -avPz 192.168.37.131:/root/remote ./local/
 
拉数据指定用10022端口
rsync -avPz -e "ssh -p 10022"  192.168.37.131:/root/remote ./local/
 
3、对比测试:    tree local;    tree remote/local
 
 
【b】后台模式   ——》 假设128是rsync服务器,131是远程机器
研发人员上线新版本,导致服务器挂了或者不正常,要进行版本回滚(恢复原来的状态, rsync服务器,容易出现 io压力,因为要上传。1k~2k压力可以扛得住)
 
(1)客户端从服务端拉取数据:
----- 服务端操作
1、编写rsync的配置文件: /etc/rsyncd.conf
[root@windysai ~]# cat /etc/rsyncd.conf
 
 port=
log file=/var/log/rsync.log
pid file=/var/run/rsync.pid
#address # 启动rsync服务的ip [jiayi] #服务端自定义的模块名
path=/tmp/rsync #数据存放路径
use chroot=yes #把同步的用户限定在path目录下,不能备份指向外部符号链接所指向的目录文件
max connections= #0代表没有限制
read only=yes
list=yes #允许列出模块名
uid=root #以哪个用户身份同步数据(属主属组)
gid=root
auth users=jiayi #指定传输时使用的用户名;和secrets成对出现,如果两个同时注释,就是root拷贝
secrets file=/etc/rsyncd.passwd #存密码文件
hosts allow=192.168.37.131 #白名单(没写:all) 指定被允许连接该模块的主机,多个ip用空格隔开
2、编辑密码文件,保存并赋予600
(1)vim /etc/rsyncd.passwd
jiayi:123aaa # 用户名: 密码
(2)chmod 600  /etc/rsyncd.passwd
 
3、启动rsync服务(端口8730)
rsync --daemon --config=/etc/rsyncd.conf    #时时生效,不用重启
 

4、建立目录并创建测试文件

(1)mkdir /tmp/rsync
(2)echo "1.txt de content" >> /tmp/rsync/1.txt

----- 客户端操作

客户端测试(sai:131)
1、cat rsyncd.passwd
 123aaa

2、chown jiayi:jiayi rsyncd.passwd
3、chmod 600 rsyncd.passwd

 
4、rsync -avzP --port 8730 jiayi@192.168.37.128::jiayi/1.txt ./ --password-file=/home/jiayi/rsyncd.passwd
默认是连 873 端口

ps :  如果没有配置1,2,3步,直接运行4,则终端需要输入密码: 123aaa  才可以传输
 
 
(2)客户端推送数据到服务端:
1、修改配置文件
vim /etc/rsyncd.conf
——》 read only 改成 no
 
2、客户端执行
rsync -avzP --port 8730 /tmp/123 jiayi@192.168.37.128::jiayi/

因为传输时没有指定--password-file,所以需要输入密码

 
3、服务端查看
cd /tmp/rsync
——》 有目录 123
 
 
 

rsync工具的更多相关文章

  1. rsync工具介绍

    rsync工具介绍 http://man.linuxde.net/rsync rsync命令是一个远程数据同步工具,可通过LAN/WAN快速同步多台主机间的文件.rsync使用所谓的“rsync算法” ...

  2. rsync工具、rsync常用选项、以及rsync通过ssh同步 使用介绍

    第8周5月14日任务 课程内容: 10.28 rsync工具介绍10.29/10.30 rsync常用选项10.31 rsync通过ssh同步 10.28 rsync工具介绍 rsync是一个同步的工 ...

  3. 使用rsync工具构建php项目管理平台

    对于phper来说部署项目和更新项目是很方便的,只要直接将写好的项目覆盖到项目的根目录就可以啦.但是平时项目开发的时候肯定不是只部署一个环境,一般是三套环境(开发环境.测试环境.生产环境),我们每次在 ...

  4. Linux centos7 rsync工具介绍、rsync常用选项、rsync通过ssh同步

    一.rsync工具介绍 rsync是类unix系统下的数据镜像备份工具,从软件的命名上就可以看出来了——remote sync.rsync是Linux系统下的文件同步和数据传输工具,它采用“rsync ...

  5. rsync工具介绍 rsync常用选项 rsync通过ssh同步

    linux文件同步工具-rsync [root@centos7 tmp]# yum install -y rsync rsync可以增量的同步,只同步变更的文件 把/etc/passwd 同步到/tm ...

  6. Linux 笔记 - 第十三章 Linux 系统日常管理之(四)Linux 中 rsync 工具和网络配置

    博客地址:http://www.moonxy.com 一.前言 rsync 命令是一个远程数据同步工具,可通过 LAN/WAN 快速同步多台主机间的文件,可以理解为 remote sync(远程同步) ...

  7. linux下一个rsync工具和配置

    本文介绍了整个基本:http://www.2cto.com/os/201308/238733.html 一些简单的备忘录: 1. ubuntu下通过apt-get就可以安装: 2. 配置文件/etc/ ...

  8. Linux实战教学笔记21:Rsync数据同步工具

    第二十一节 Rsync数据同步工具 标签(空格分隔): Linux实战教学笔记-陈思齐 ---本教学笔记是本人学习和工作生涯中的摘记整理而成,此为初稿(尚有诸多不完善之处),为原创作品,允许转载,转载 ...

  9. Rsync,Linux日志及Screen工具介绍

    第十六次课 Rsync,Linux日志及Screen工具介绍 目录 一.rsync工具介绍 二.rsync常用选项 三.rsync通过ssh同步 四. rsync通过服务同步 五.linux系统日志 ...

随机推荐

  1. 巨蟒django之权限7:动态生成一级&&二级菜单

    内容回顾: . 权限的控制 . 表结构设计 存权限的信息 用户表 - name 用户名 - pwd 密码 - roles 多对多 角色表 - name - permissions 多对多 权限表 - ...

  2. POI解析Excel封装工具

    1. [代码][Java]代码     跳至 [1] [全屏预览] ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 2 ...

  3. Vue的插值与表达式

    正常情况我们在页面取值都是通过 {{ data }}来取值,但是有时候我们就是想输出HTML,而不是将数据解析后的纯文本,这个时候可以使用v-html来绑定数据 <span v-html=&qu ...

  4. Django报:AttributeError: tuple object has no attribute get

    def index(request): hero_list=models.HeroInfo.objects.all() return render_to_response('index.html',{ ...

  5. Redis3.2.5配置主从服务器遇到的一些错误

    注意:关闭主从服务器的防火墙 问题一: WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net ...

  6. python 获取当前运行的 class 和 方法的名字

    # coding=utf-8 import sys class Hello(): def hello(self): print('the name of method is ## {} ##'.for ...

  7. 0404-服务注册与发现-客户端负载均衡-两种自定义方式-Ribbon通过代码自定义配置、使用配置文件自定义Ribbon Client

    一.官方文档解读 官方地址:https://cloud.spring.io/spring-cloud-static/Edgware.SR3/single/spring-cloud.html#_cust ...

  8. 004-ibus输入法,快捷键,浏览器

    一.输入法 用 root 身份在终端下,运行下面命令: yum install ibus-pinyin ibus ibus-gtk ibus-qt 使用im-chooser命令,选择ibus为默认输入 ...

  9. 016-Hadoop Hive sql语法详解6-job输入输出优化、数据剪裁、减少job数、动态分区

    一.job输入输出优化 善用muti-insert.union all,不同表的union all相当于multiple inputs,同一个表的union all,相当map一次输出多条 示例 二. ...

  10. springboot 常用的异常处理方式

    springboot常用的异常处理推荐: 一.创建一个异常控制器,并实现ErrorController接口: package com.example.demo.controller; import o ...