增量备份之rsync(ubuntu16.04)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_14845119/article/details/85339264

rsync(remote synchronize) 是一个远程数据同步工具,可以使用“rsync算法”同步本地和远程主机之间的文件。rsync的好处是只同步两个文件不同的部分,相同的部分不在传递。类似于增量备份,这使的在服务器传递备份文件或者同步文件,比起scp工具要省时间,带宽

 

Ubuntu16.04默认安装rsync,但是没有默认启动

安装及启动:

sudo vim /etc/default/rsync
将RSYNC_ENABLE=false改为true
RSYNC_ENABLE=true 
sudo cp /usr/share/doc/rsync/examples/rsyncd.conf  /etc
sudo vim /etc/rsyncd.conf
修改path路径,然后启动
sudo /etc/init.d/rsync start

配置文件参数说明(rsyncd.conf):

# sample rsyncd.conf configuration file

# GLOBAL OPTIONS

#motd file=/etc/motd #登录欢迎信息
#log file=/var/log/rsyncd #日志文件
# for pid file, do not use /var/run/rsync.pid if
# you are going to run rsync out of the init.d script.
pid file=/var/run/rsyncd.pid

#指定rsync发送日志消息给syslog时的消息级别,常见的消息级别是:uth, authpriv, cron, daemon, ftp, kern, lpr, mail, news, security, sys-log, user, uucp, local0, local1, local2, local3,local4, local5, local6和local7。默认值是daemon。
#syslog facility=daemon

#自定义tcp选项,默认是关闭的
#socket options=

#以下是模块信息,我们可以创建多个模块
# MODULE OPTIONS

[ftp]#rsync方式备份时的参数,可以修改为别的名字

        comment = public archive #模块描述
        path = /var/www/pub #需要同步的路径
        use chroot = yes #默认是yes|true,如果为true,那么在rsync在传输文件以前首先chroot到path参数指定的目录下。这样做的原因是实现额外的安全防护,但是缺点是需要root权限,并且不能备份指向外部的符号连接指向的目录文件。
#       max connections=10 #最大连接数
        lock file = /var/lock/rsyncd #指定支持max connections参数的锁文件。
# the default for read only is yes...
        read only = yes #只读选项,默认为yes,只可以进行下行同步,若要进行上行同步需要改为no
        list = yes #客户请求时可用模块时是否列出该模块
        uid = nobody #设定该模块传输文件时守护进程应该具有的uid
        gid = nogroup #设定该模块传输文件时守护进程应具有的gid,此项与uid配合可以确定文件的访问权限
#       exclude = #用来指定多个由空格隔开的多个模式列表,并将其添加到exclude列表中。这等同于在客户端命令中使用--exclude来指定模式,不过配置文件中指定的exlude模式不会传递给客户端,而仅仅应用于服务器。一个模块只能指定一个exlude选项,但是可以在模式前面使用"-"和"+"来指定是exclude还是include    #这个我的理解是排除目录中不需同步的文件
#       exclude from = #可以指定一个包含exclude模式定义的文件名
#       include = #与exclude相似
#       include from = #可以指定一个包含include模式定义的文件名
#       auth users = #该选项指定由空格或逗号分隔的用户名列表,只有这些用户才允许连接该模块。这里的用户和系统用户没有任何关系。如果"auth users"被设置,那么客户端发出对该模块的连接请求以后会被rsync请求challenged进行验证身份这里使用的 challenge/response认证协议。用户的名和密码以明文方式存放在"secrets file"选项指定的文件中。默认情况下无需密码就可以连接模块(也就是匿名方式)
#       secrets file = /etc/rsyncd.secrets #该文件每行包含一个username:password对,以明文方式存储,只有在auth users被定义时,此选项才生效。同时我们需要将此文件权限设置为0600
        strict modes = yes #该选项指定是否监测密码文件的权限,如果该选项值为true那么密码文件只能被rsync服务器运行身份的用户访问,其他任何用户不可以访问该文件。默认值为true
#       hosts allow = #允许的主机
#       hosts deny = #拒绝访问的主机
        ignore errors = no #设定rsync服务器在运行delete操作时是否忽略I/O错误
        ignore nonreadable = yes #设定rysnc服务器忽略那些没有访问文件权限的用户
        transfer logging = no #使rsync服务器使用ftp格式的文件来记录下载和上载操作在自己单独的日志中
#       log format = %t: host %h (%a) %o %f (%l bytes). Total %b bytes. #设定日志格式
        timeout = 600 #超时设置(秒)
        refuse options = checksum dry-run #定义一些不允许客户对该模块使用的命令选项列表
        dont compress = *.gz *.tgz *.zip *.z *.rpm *.deb *.iso *.bz2 *.tbz #告诉rysnc那些文件在传输前不用压缩,默认已设定压缩包不再进行压缩

基本命令:

启动:sudo /etc/init.d/rsync start

重启:sudo /etc/init.d/rsync restart

关闭:sudo /etc/init.d/rsync stop

查看状态:sudo /etc/init.d/rsync status

上传下载:rsync [选项] 原始位置 目标位置

参数:

-a 归档模式,递归并保留对象属性,等同于 -rlptgoD
-v 显示同步过程的详细(verbose)信息
-z 在传输文件时进行压缩(compress)
-H 保留硬链接文件
-A 保留ACL属性
--delete 删除目标位置有而原始位置没有的文件
-r 递归模式,包含目录及子目录中所有文件
-l 对于软链接文件仍然复制为软链接文件
-p 保留文件的权限标记
-t 保留文件的时间标记
-g 保留文件的属组标记(仅超级用户使用)
-o 保留文件的属主标记(仅超级用户使用)
-D 保留设备文件及其他特殊文件

同步方式:

rsync支持两种同步源,一种是基于SSH的同步源,另一种是基于rsync的同步源。SSH方式类似于scp操作,无需开启rsync服务,rsync方式需要在服务端开启rsync服务。

使用上行同步的方式,要将配置文件rsyncd.conf中,设置read only = no。

下面同步命令中username去掉也可以同步。

下行同步:客户端操作,将服务端的文件下载到客户端

上行同步:客户端操作,将客户端的文件上传到服务端

SSH方式同步:

下行同步:rsync -avz 用户名@服务器地址:/服务器目录 /本地目录 

rsync  -avz  [email protected]:/srv/ftp/pub/*  ./

上行同步:rsync -avz /本地目录 用户名@服务器地址:/服务器目录

rsync  -avz  ./1.txt  [email protected]:/srv/ftp/pub/

rsync方式同步:

下行同步:rsync -avz 用户名@服务器地址::ftp  /本地目录 

rsync  -avz  --progress  --delete  [email protected]::ftp  ./

上行同步:rsync -avz /本地目录 用户名@服务器地址::ftp 

rsync  -avz  --progress  --delete  ./1.txt  [email protected]::ftp

 

 

猜你喜欢

转载自blog.csdn.net/qq_14845119/article/details/85339264