1、在服务端编辑配置文件

  1. [root@game_intf ~]# more /etc/rsyncd.conf
  2. port=8730
  3. log file=/var/log/rsync.log
  4. pid file=/var/run/rsync.pid
  5. [abc]
  6. path=/tmp/123
  7. use chroot=yes
  8. max nonections=4
  9. read only=yes
  10. list=yes
  11. uid=root
  12. gid=root
  13. auth users=abc
  14. secrets file=/etc/rs.passwd

复制代码

说明:
配置文件 /etc/rsyncd.conf ,内容如下:
#port=873        #监听端口默认为873,也可以是别的端口
log file=/var/log/rsync.log  #指定日志
pid file=/var/run/rsyncd.pid  #指定pid
#address=192.168.0.10  #可以定义绑定的ip
以上部分为全局配置部分,以下为模块内的设置
[abc]    #为模块名,自定义
path=/tmp/123   # 指定该模块对应在哪个目录下
use chroot=true #是否限定在该目录下,默认为true,当有软连接时,需要改为fasle,如果为true就限定为模块默认目录
max connections=4  # 指定最大可以连接的客户端数
read only=no #是否为只读,如果是no的话,客服端推送给服务端的时候不成功,这时候要改成yes
list=true #是否可以列出模块名    rsync --port 8730   172.16.37.139::  如果为yes的话会列出客户端所有的模块名字。  
uid=root #以哪个用户的身份来传输   
gid=root  #以哪个组的身份来传输
auth users=test #指定验证用户名,可以不设置,不设置默认不用密码,设置的话安全性更高点
secrets file=/etc/rsyncd.passwd #指定密码文件,如果设定验证用户,这一项必须设置,设定密码权限为400.
hosts allow=192.168.0.101 #设置可以允许访问的主机,可以是网段,多个Ip地址用空格隔开
密码文件/etc/rsyncd.passwd的内容格式为:username:password 
启动服务的命令是:rsync --daemon 
默认去使用/etc/rsyncd.conf这个配置文件,也可以指定配置文件 rsync --daemon --config=/etc/rsyncd2.conf,更改配置文件不用重启服务,即时生效。 

2、在客户端保存服务端的密码文件权限为400,以便脚本使用。

  1. [root@game_app ~]# more /etc/123.pass
  2. abc123

复制代码

3、把客户端的123文件下的内容放到服务端,这是服务端的read-only 要改成no,否则上传不成功。

  1. [root@game_app ~]# rsync -avPz  --port 8730 123/  --password-file=/etc/123.pass  abc@172.16.37.139::abc
  2. sending incremental file list
  3. ./
  4. anaconda-ks.cfg
  5. 1338 100%    0.00kB/s    0:00:00 (xfer#1, to-check=1/3)
  6. install.log
  7. 49733 100%   11.86MB/s    0:00:00 (xfer#2, to-check=0/3)
  8. sent 12379 bytes  received 49 bytes  24856.00 bytes/sec
  9. total size is 51071  speedup is 4.11

复制代码

4、在客户端查看服务端的模块名字,无需密码

  1. [root@game_app ~]# rsync --port 8730 172.16.37.139::
  2. abc

复制代码

5、服务端不需要同步给客户端的文件,加上--exclude=filename

  1. [root@game_intf 123]# rsync -avzP  --exclude=install.log --exclude=2 /tmp/123/ itv@172.16.37.140:/home/itv/123
  2. itv@172.16.37.140's password:
  3. sending incremental file list
  4. ./
  5. 3231231
  6. 0 100%    0.00kB/s    0:00:00 (xfer#1, to-check=3/5)
  7. anaconda-ks.cfg
  8. 1338 100%    0.00kB/s    0:00:00 (xfer#2, to-check=2/5)
  9. as
  10. 0 100%    0.00kB/s    0:00:00 (xfer#3, to-check=1/5)
  11. ppppppp/
  12. sent 1057 bytes  received 76 bytes  151.07 bytes/sec
  13. total size is 1338  speedup is 1.18

复制代码

6、rsync 参数选项详解。

  1. -a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
  2. -r, --recursive 对子目录以递归模式处理
  3. -l, --links 保留软链结
  4. -p, --perms 保持文件权限
  5. -t, --times 保持文件时间信息
  6. -o, --owner 保持文件属主信息
  7. -g, --group 保持文件属组信息
  8. -D, --devices 保持设备文件信息
  9. --delete 删除那些DST中SRC没有的文件   。 会把目的文件中没有的文件删掉
  10. --delete-excluded 同样删除接收端那些被该选项指定排除的文件
  11. --delete-after 传输结束以后再删除
  12. --exclude=PATTERN 指定排除不需要传输的文件模式
  13. -P 等同于 --partial --progress 显示备份过程
  14. -u, --update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件,不覆盖更新的文件

复制代码

7、
a、如果对端机器走的不是默认22端口的话,同步时候要加上 -e "ssh -p port"

  1. [root@game_intf 123]# rsync -avzP -s "ssh -p 22" /tmp/123/ itv@172.16.37.140:/home/itv/123

复制代码

b、如果是创建秘钥对,机器互相信任,需要加上 "--rsh=ssh -p port” 
rsync -av "--rsh=ssh -p port”  /dir1/ 192.168.0.101:/tmp/dir2/ 

rsync.conf详解的更多相关文章

  1. rsync指令详解

    rsync指令详解(更详细的看官方文档http://rsync.samba.org/ftp/rsync/rsync.html) [root@Centos epel]# rsync --help rsy ...

  2. (转)Rsync命令详解

    Rsync命令详解 原文:http://blog.51cto.com/irow10/1826249 说明: Rsync是linux/Unix文件同步和传送工具.用于替代rcp的一个工具,rsync可以 ...

  3. rsync参数详解

    Rsync的参数详细解释 -v, --verbose 详细模式输出-q, --quiet 精简输出模式-c, --checksum 打开校验开关,强制对文件传输进行校验-a, --archive 归档 ...

  4. rsync命令详解、rsync用ssh隧道方式同步

    ● rsync格式安装命令 yum install -y rsync与scp的区别:scp复制为完全覆盖,rsync为增量同步,只同步修改过的数据.rsync命令格式如下: rsync 选项 源文件 ...

  5. Redis:默认配置文件redis.conf详解

    转: Redis:默认配置文件redis.conf详解 # Redis配置文件样例 # Note on units: when memory size is needed, it is possibl ...

  6. Redis配置文件redis.conf详解

    一.Redis配置文件redis.conf详解 # Note on units: when memory size is needed, it is possible to specifiy # it ...

  7. linux离线部署redis及redis.conf详解

    一.离线部署redis 由于博主部署的虚拟机没有网络也没有gcc编译器,所以就寻找具备gcc编译器的编译环境把redis编译安装好,Copy Redis安装目录文件夹到目标虚拟机的目录下.copy时r ...

  8. yum的配置文件yum.conf详解

    说明:经过网上抄袭和自己的总结加实验,非常详细,可留作参考. yum的配置一般有两种方式:   一种是直接配置/etc目录下的yum.conf文件, 另外一种是在/etc/yum.repos.d目录下 ...

  9. /etc/security/limits.conf 详解与配置

    目录 一. /etc/security/limits.conf 详解 /etc/security/limits.conf 配置解析 /etc/security/limits.d/ 目录 二. ulim ...

随机推荐

  1. Java 中JOptionPane的基本使用方法

    JOptionPane 有助于方便地弹出要求用户提供值或向其发出通知的标准对话框.但是有时候看看API也特别烦,因为方法多,参数多,特别难记忆.这里我给出几种常用的方法供大家参考. (1) publi ...

  2. Docker容器基础知识学习

    Docker作为操作系统层面的轻量级的虚拟化技术,凭借简易的使用.快速的部署以及灵活敏捷的集成等优势,迅速发展目前最为火热的技术. 1.云计算服务是一种资源管理的资源服务,该模式可以实现随时随地.便捷 ...

  3. UIView不接受触摸事件的三种情况

    1.不接收用户交互 userInteractionEnabled = NO 2.隐藏 hidden = YES 3.透明 alpha = 0.0 ~ 0.01 4. 如果子视图的位置超出了父视图的有效 ...

  4. 清北学堂模拟day4 捡金币

    [问题描述]小空正在玩一个叫做捡金币的游戏.游戏在一个被划分成 n行 n列的网格状场地中进行.每一个格子中都放着若干金币,并且金币的数量会随着时间而不断变化. 小空的任务就是在网格中移动,拾取尽量多的 ...

  5. sqlite 去除换行符

    去除换行符操作: update t_config_list ;

  6. leofs存储总结

    1.leofs角色 Account(账户).Bucket(对象桶).Object(对象), gateway.manager0.manager1.storage Account 一个account可以创 ...

  7. Angular.js入门教程

    简单介绍 AngularJS是为了克服HTML在构建应用上的不足而设计的.首先Html是一门很好的为静态文本展示设计的声明式语言,但要构建WEB应用的话它就显得乏力了. 通常,我们可以通过以下技术来解 ...

  8. The report for triangle problem

    本次实验主要使用eclipse 编写三角形判定的代码,并用junit进行测试. 1.安装junit和hamcrest 下载junit-4.12.jar和hamcrest-all-1.3.jar 并且拖 ...

  9. iOS开发——高级篇——如何集成支付宝SDK

    一.什么是支付宝 第三方支付平台 和内购非常相似内购是用户将钱付款给苹果,之后苹果分成给商户支付宝是用户将钱付款给支付宝,之后支付宝将钱转入我们的账户 使用支付宝前提购买的物品必须是和应用程序无关的. ...

  10. javascript中数组concat()join()split()

    concat() 方法用于连接两个或多个数组. 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本. 所以 <script type="text/javascript" ...