选项 | 说明 |
---|---|
-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/ mysql@192.168.136.136:/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 rsbak@192.168.136.135::backup /tmp/2021/c --password-file=/etc/rsync.password
3、往服务端推送文件
rsync -avz --progress /tmp/2021/c/ rsbak@192.168.136.135::backup --password-file=/etc/rsync.password
4、排除指定文件和目录
rsync -avz --progress --exclude=hell.txt rsbak@192.168.136.135::backup /tmp/2021/c --password-file=/etc/rsync.password
rsync -avz --progress --exclude=/135/ rsbak@192.168.136.135::backup /tmp/2021/c --password-file=/etc/rsync.password
rsync -avz --progress --exclude-from=/tmp/2021/excefile.conf rsbak@192.168.136.135::backup /tmp/2021/c --password-file=/etc/rsync.password
vi /tmp/2021/excefile.conf
/135/
hell.txt