rsync常用命令

选项 说明
-a, ––archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等价于 -rlptgoD (注意不包括 -H)
-r, ––recursive 对子目录以递归模式处理
-l, ––links 保持符号链接文件
-H, ––hard-links 保持硬链接文件
-p, ––perms 保持文件权限
-t, ––times 保持文件时间信息。强烈建议任何时候都加上"-t",否则目标文件mtime会设置为系统时间,导致下次更新检查出mtime不同从而导致增量传输无效。
-g, ––group 保持文件属组信息
-o, ––owner 保持文件属主信息 (super-user only)
-D 保持设备文件和特殊文件 (super-user only)
-z, ––compress 在传输文件时进行压缩处理
––exclude=PATTERN 指定排除一个不需要传输的文件匹配模式
––exclude-from=FILE 从 FILE 中读取排除规则
––include=PATTERN 指定需要传输的文件匹配模式
––include-from=FILE 从 FILE 中读取包含规则
––copy-unsafe-links 拷贝指向SRC路径目录树以外的链接文件
––safe-links 忽略指向SRC路径目录树以外的链接文件(默认)
––existing 仅仅更新那些已经存在于接收端的文件,而不备份那些新创建的文件
––ignore-existing 忽略那些已经存在于接收端的文件,仅备份那些新创建的文件
-b, ––backup 当有变化时,对目标目录中的旧版文件进行备份
––backup-dir=DIR 与 -b 结合使用,将备份的文件存到 DIR 目录中
––link-dest=DIR 当文件未改变时基于 DIR 创建硬链接文件
––delete 删除那些接收端还有而发送端已经不存在的文件
––delete-before 接收者在传输之前进行删除操作 (默认)
––delete-during 接收者在传输过程中进行删除操作
––delete-after 接收者在传输之后进行删除操作
––delete-excluded 在接收方同时删除被排除的文件
-e, ––rsh=COMMAND 指定替代 rsh 的 shell 程序
––ignore-errors 即使出现 I/O 错误也进行删除
––partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输
––progress 在传输时显示传输过程
-P 等价于 ––partial ––progress
––delay-updates 将正在更新的文件先保存到一个临时目录(默认为 “.~tmp~”),待传输完毕再更新目标文件
-v, ––verbose 详细输出模式
-q, ––quiet 精简输出模式
-h, ––human-readable 输出文件大小使用易读的单位(如,K,M等)
-n, ––dry-run 显示哪些文件将被传输
––list-only 仅仅列出文件而不进行复制
––rsyncpath=PROGRAM 指定远程服务器上的 rsync 命令所在路径
––password-file=FILE 从 FILE 中读取口令,以避免在终端上输入口令,通常在 cron 中连接 rsync 服务器时使用
-4, ––ipv4 使用 IPv4
-6, ––ipv6 使用 IPv6
--bwlimit=KBPS 限制I/O带宽
––version 打印版本信息
––help 显示帮助信息

说明:-avz 相当于 –vzrtopgDl
生产环境中常用: –avz 或 –vzrtopg

一、单个主机本地之间的数据传输

1、将a目录内容同步到b目录
rsync -avz --progress a/ b


2、将 /tmp/2021/a/hell.txt 文件复制到 /tmp/2021/b/ 目录下
rsync --progress /tmp/2021/a/hell.txt /tmp/2021/b/

二、ssh通道来传输数据

1、将 /tmp/2021/a/ 目录内容同步到远程主机的 /tmp/2021/c 目录(需输入密码)
rsync -r --progress /tmp/2021/a/ [email protected]:/tmp/2021/c -e 'ssh -p 22'

三、守护进程模式

服务端配置

# 设置 selinux 为 disabled,需要重启生效
vi /etc/selinux/config

SELINUX=disabled

1、安装
yum install rsync


2、配置文件:/etc/rsyncd.conf

vi /etc/rsyncd.conf

uid = mysql                        #运行进程的用户
gid = mysql                        #运行进程的用户组
port = 873                         #监听端口 
use chroot = no                    #安全性,内网一般不考虑,设为no
max connections = 200              #最多有多少个客户端连接我
timeout = 300                      #超时时间,秒
pid file = /var/run/rsyncd.pid     #pid文件
lock file = /var/run/rsync.lock    #传输时会给文件加锁
log file = /var/log/rsyncd.log     #日志文件
ignore errors                      #传输过程中遇到错误,自动忽略
read only = false                  #可读可写
list = false                       #不允许列表
hosts allow = 192.168.136.0/24     #允许的IP段
#hosts deny =                      #拒绝
auth users = rsbak                 #这是个虚拟用户
secrets file = /etc/rsync.password #虚拟用户对应的密码文件

[backup]                           #模块
path=/tmp/2021/a                   #客户端来同步,就是同步该目录


3、授权
chown -R mysql.mysql /tmp/2021/a


4、在 /etc/rsync.password 中添加虚拟用户
echo "rsbak:hadoop" > /etc/rsync.password
chmod 600 /etc/rsync.password


5、启动服务端, 以守护进程方式
rsync --daemon --config=/etc/rsyncd.conf
或: systemctl start rsyncd

6、添加开机启动
echo "/usr/bin/rsync --daemon --config=/etc/rsyncd.conf" >> /etc/rc.local

客户端配置

1、配置密码文件,文件里只存放密码
echo "hadoop" > /etc/rsync.password
chmod 600 /etc/rsync.password


2、从服务端拉取文件
rsync -avz --progress [email protected]::backup /tmp/2021/c --password-file=/etc/rsync.password

3、往服务端推送文件
rsync -avz --progress /tmp/2021/c/ [email protected]::backup --password-file=/etc/rsync.password


4、排除指定文件和目录
rsync -avz --progress --exclude=hell.txt [email protected]::backup /tmp/2021/c --password-file=/etc/rsync.password
rsync -avz --progress --exclude=/135/ [email protected]::backup /tmp/2021/c --password-file=/etc/rsync.password

rsync -avz --progress --exclude-from=/tmp/2021/excefile.conf [email protected]::backup /tmp/2021/c --password-file=/etc/rsync.password

vi /tmp/2021/excefile.conf

/135/
hell.txt

你可能感兴趣的:(Linux运维)