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. [翻译] flask-SocketIO

    最近开发工作需要用到websocket去替代老办法轮询,因为我们的web系统使用flask搭建,所以使用flask-SocketIO作为我们的websocket方案,因此顺手翻译官方文档 *** Fl ...

  2. python多进程编程(一)

    multiprocessing模块介绍 python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu_count()查看),在python中大部分情况需要使用多进程.Pyt ...

  3. python多线程(三)

    同步锁 两个需要注意的点: 线程抢的是GIL锁,GIL锁相当于执行权限,拿到执行权限后才能拿到互斥锁Lock,其他线程也可以抢到GIL,但如果发现Lock仍然没有被释放则阻塞,即便是拿到执行权限GIL ...

  4. spring中配置缓存—ehcache

    常用的缓存工具有ehcache.memcache和redis,这里介绍spring中ehcache的配置. 1.在pom添加依赖: <!-- ehcache 相关依赖 --> <de ...

  5. Python基础-序列化(json/pickle)

    我们把对象(变量)从内存中变成可存储的过程称之为序列化,比如XML,在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flattening等 ...

  6. 流量监控系统---storm集群配置

    1.集群部署的基本流程 集群部署的流程:下载安装包.解压安装包.修改配置文件.分发安装包.启动集群 注意: 所有的集群上都需要配置hosts vi  /etc/hosts 192.168.223.20 ...

  7. 类百度DOC编辑区域

    .mainarea{ position:absolute; top:151px; width:100%; bottom:0px; } .edit_wrap{ background:#fcfcfc; p ...

  8. 面对 to B 业务该如何构建研发管理体系?

    未来离我们越来越近,而过去并未走远,我们发现科技公司2B业务兴起,腾讯认为互联网下半场属于产业互联网,需要进行一次重要的战略升级.它们在国庆节最后一天进行新一轮组织架构调整,最亮眼的就是新成立云与智慧 ...

  9. 版本控制系统Subversion

    系统提供撤销的功能对我们实际开发中特别重要.改动后撤销几乎也是我们每个人经常做的事情.再多人进行同一个项目的开发或者测试的时候,版本的唯一性(类似于临界区资源),也就是说A 和B 两个人协同工作的时候 ...

  10. hadoop04---shell

    Linux上的mysql安装之后卸载是卸载不干净的,ping服务器ping不通就是把icmp协议关闭了,ping使用的是icmp协议. Export是全局变量,所有用户登录进来都可以使用. 1.ipt ...