阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Rsync文件同步学习

74次阅读
没有评论

共计 2625 个字符,预计需要花费 7 分钟才能阅读完成。

导读 前段时间因公司需求,需要把备份的文件进行同步保存,后面就想到了我们大家都最熟悉的文件同步工作 Rsync,于是就捣鼓了一下午时间,然后总结了下大概过程和参数详情。

首先了解了下 rsync 同步的大致原理:Rsync 同步使用所谓的“Rsync 演算法”来使本地和远程两个主机之间的文件达到同步,这个算法只传送两个文件的不同部分,而不是每次都整份

传送,因此传输的速度相当快。Rsync 服务端会打开一个 873 的服务通道(port),等待客户端 Rsync 连接。连接时,Rsync 服务端会检查口令(passwd)是否相符,若通过口令查核,

则可以开始进行文件传输。第一次连通完成时,会把整份文件传输一次,下一次就只传送二个文件之间的差异部份。

接下来我们就来初步搭建,先完成任务需求。

Rsync 服务端(192.168.177.130)

安装 rsync 工具

yum -y install rsync

(默认会在 etc 目录下生成一个 rsync 的配置文件)

编辑配置文件 rsyncd.conf(配置文件里面是不能添加注释,不然会报错)

uid = root                     
gid = root
use chroot = no
max connections = 4
#pid file = /var/run/rsyncd.pid      
lock file = /var/run/rsyncd.lock
log file = /var/log/rsyncd.log         
exclude = lost+found/
transfer logging = yes
timeout = 600
ignore nonreadable = yes           
dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2         
[test]                                  
path = /home/rsynctest
ignore errors = yes
read only = yes
write only = no
hosts allow = 192.168.177.131    
hosts deny = *
list = false
uid = root 
gid = root
auth users = root
secrets file = /etc/rsyncd.passwd

配置详解

uid = root                 #设置运行 rsync 进程的用户
gid = root
use chroot = no            #使用默认根目录
max connections = 4        #最大连接数
#pid file = /var/run/rsyncd.pid        #CentOS7 中 yum 安装 不需指定 pid file 否则报错
lock file = /var/run/rsyncd.lock       #指定支持 max connections 参数的锁文件
log file = /var/log/rsyncd.log         #此文件定义完成后 系统会自动创建
exclude = lost+found/
transfer logging = yes             #使 rsync 服务器使用 ftp 格式的文件来记录下载和上载操作在自己单独的日志中
timeout = 600   #通过该选项可以覆盖客户指定的 IP 超时时间。通过该选项可以确保 rsync 服务器不会永远等待一个崩溃的客户。超时单位为秒钟,0 表示没有超时定义,这也是默认值。对于匿名 rsync 服务器来说,一个理想的数字是 600。ignore nonreadable = yes           #同步时跳过没有权限的目录
dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2          #传输时不压缩的文件
[test]                          #此名字即客户端使用 rsync 来同步的路径
path = /home/rsynctest                 #实际需要同步的路径
ignore errors = yes     #指定 rsyncd 在判断是否运行传输时的删除操作时忽略 server 上的 IP 错误,一般来说 rsync 在出现 IO 错误时将将跳过 --delete 操作,以防止因为暂时的资源不足或其它 IO 错误导致的严重问题
read only = yes         #表示可以 pull
write only = no         #表示不可以 push
hosts allow = 192.168.177.131        #客户端同步的地址
hosts deny = *   #指定不允许连接 rsync 服务器的机器,可以使用 hosts allow 的定义方式来进行定义。默认是没有 hosts deny 定义。list = false     #该选项设定当客户请求可以使用的模块列表时,该模块是否应该被列出。如果设置该选项为 false,可以创建隐藏的模块。默认值是 true。uid = root       #获取文件的身份
gid = root
auth users = root  #客户端获取文件的身份 此用户并不是本机中确实存在的用户
secrets file = /etc/rsyncd.passwd   #用来认证客户端的秘钥文件 格式 USERNAME:PASSWD 此文件权限一定需要改为 600,且属主必须与运行 rsync 的用户一致。(需自行创建)

创建对应密码文件

vim /etc/rsyncd.passwd
 格式如下:root:123456(前用户名后密码)
 修改文件权限:chmon 600 /etc/rsyncd.passwd
 启动 rsync 服务端:sudo rsync --daemon(客户端不用启动)
Rsync 客户端(192.168.177.131)

安装 rsync 工具

  yum -y install rsync(默认会在 etc 目录下生成一个 rsync 的配置文件)

配置认证密码文件

  echo passwd(只需要密码就行)>> /etc/rsyncd.passwd

修改权限

  chmon 600 /etc/rsyncd.passwd

测试文件同步情况:

  rsync -avz --progress --password-file=/etc/rsyncd.passwd root@192.168.177.130::rsynctest /tmp/rsynctest/

Rsync 文件同步学习

测试完成!

命令参数详解:

  -v, –verbose 详细模式输出

  -z, –compress 对备份的文件在传输时进行压缩处理

  -r, –recursive 对子目录以递归模式处理

  -t, –times 保持文件时间信息

  -o, –owner 保持文件属主信息

  -p, –perms 保持文件权限

  -g, –group 保持文件属组信息

  –-progress 显示传输进度

  --delete 删除客户端多余文件 

总结的还不到位,希望有问题可以指出!

Just Do It

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计2625字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中