微信关注,获取新知

rsync增量备份同步数据到备用服务器

如今不论我们使用哪家的服务器,数据安全都是有风险的。即便我们做的多好的防御,也需要用到定期备份数据。一般我们备份数据会采用快照备份、手工定期备份,或者用 rsync增量备份。在这里我们介绍 rsync增量备份的基本流程。

安装rsync

CentOS/Fedora/RHEL: yum install rsync
Debian/Ubuntu: apt-get install rsync

rsync使用教程

rsync有两种工作方式:SSH和daemon

SSH方式是使用系统上的用户通过SSH进行同步操作。daemon方式是rsync服务器会开一个873端口,等待客户端去连接,连接是进行验证,通过后进行同步。

一、SSH模式下进行同步操作

rsync -options SRC DEST

SRC代表源目录,DEST代表目标目录,当通过ssh链接时, 有时需要指定ssh端口, 请使用这个方式:rsync -options -e “ssh -p 10000” SRC DEST

下面举例说明一下常用到的场景:

1.1:本地拷贝目录,将/home/wwwroot/laojiang/拷贝到/data/wwwroot/laojiang/

rsync -avu /home/wwwroot/laojiang/ /data/wwwroot/laojiang/

1.2:将本地目录拷贝到远程服务器

rsync -avu –progress –delete /home/wwwroot/laojiang.me/ root@1.2.3.4:/home/wwwroot/laojiang.me/

如果改了SSH端口,需要加-e “ssh -p 你的SSH端口”,如果不想显示具体传输过程可以去掉P参数,如果需要压缩传输可以加z参数。

–delete 参数,这样当本地删除的文件,远程端也会删除,保持完整的一致。

1.3:将远程服务器目录拷贝到本地

rsync -avu –progress –delete root@1.2.3.4:/home/wwwroot/laojiang.me/ /home/wwwroot/laojiang.me/

二、daemon模式的配置

rsync daemon模式是以rsync服务器形式运行,首先我们需要创建rsync服务器的配置文件,配置文件:/etc/rsyncd.conf 默认此文件可能不存在,需要自己创建,配置信息如下:

port = 873
uid = root
gid = root
use chroot = no //使用chroot到文件系统中的目录中
max connections = 100 //最大并发连接数

#motd file = /etc/rsyncd.motd //定义服务器信息的,自己写 rsyncd.motd 文件内容
pid file = /var/run/rsyncd.pid
lock file = /var/run/rsyncd.lock
log file = /var/log/rsyncd.log

timeout = 300

[laojiang] //自定义模块
path = /home/wwwroot/laojiang.me/ //用来指定要备份的目录
ignore errors //可以忽略一些IO错误
read only = no //设置no,客户端可以上传文件,yes是只读
write only = no //no为客户端可以下载,yes 不能下载
hosts allow = 192.168.2.0/24 //允许连接的IP,强烈建议加上你允许的IP,多个IP逗号隔开
list = yes //客户请求时,使用模块列表
auth users = laojiang //连接用户名,是虚拟用户与linux系统用户无关,多个用户名逗号隔开
secrets file = /etc/rsyncd.secrets //验证密码文件,文件格式为:用户名:密码

写入配置时请将上面的注释信息去掉,并调整里面的相关参数。

/etc/rsyncd.secrets 文件权限必须是600,创建好该文件后可以执行: chmod 600 /etc/rsyncd.secrets

注意:默认rsync服务器并不是自动启动的!

Debian/Ubuntu上是带自启动脚本的,修改 /etc/default/rsync ,将里面的RSYNC_ENABLE=false 改成 RSYNC_ENABLE=true 保存就设成开机自启动了。

CentOS上启动脚本都是不带的,执行:wget http://soft.laojiang.me/sync/rsync/init.d.rsync -O /etc/init.d/rsync && chmod +x /etc/init.d/rsync && chkconfig rsync on 如果不报错的话就会开机自启动了。

完成上面设置后,执行:/etc/init.d/rsync start 即可启动。

测试rsync服务器:rsync -avuP laojiang@192.227.165.35::laojiang /home/wwwroot/laojiang.me/ 进行连接测试,注:@前的laojiang为自定义模块里设置的用户名,::后面的laojiang为你自定义模块的名称。

rsync 常用参数的具体解释如下:

-v, –verbose 详细模式输出
-q, –quiet 精简输出模式
-c, –checksum 打开校验开关,强制对文件传输进行校验
-a, –archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
-r, –recursive 对子目录以递归模式处理
-b, –backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用–suffix选项来指定不同的备份文件前缀。
-suffix=SUFFIX 定义备份文件前缀
-u, –update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)
-l, –links 保留软链结
-p, –perms 保持文件权限
-o, –owner 保持文件属主信息
-g, –group 保持文件属组信息
-t, –times 保持文件时间信息
-e, –rsh=COMMAND 指定使用rsh、ssh方式进行数据同步
–delete 删除那些DST中SRC没有的文件
–delete-excluded 同样删除接收端那些被该选项指定排除的文件
–delete-after 传输结束以后再删除
–ignore-errors 及时出现IO错误也进行删除
–force 强制删除目录,即使不为空
–timeout=TIME IP超时时间,单位为秒
–progress 显示备份过程
-z, –compress 对备份的文件在传输时进行压缩处理
–exclude=PATTERN 指定排除不需要传输的文件模式
–include=PATTERN 指定不排除而需要传输的文件模式
–exclude-from=FILE 排除FILE中指定模式的文件
–include-from=FILE 不排除FILE指定模式匹配的文件

投上你的一票
公众号 「老蒋朋友圈」获取站长新知 / 加QQ群 「706011751」 获取商家优惠推送

未经允许不得转载:老蒋玩运营 » rsync增量备份同步数据到备用服务器