注册 登录
  • 欢迎访问开心洋葱网站,在线教程,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站,欢迎加入开心洋葱 QQ群
  • 欢迎访问开心洋葱网站,手机也能访问哦~欢迎加入开心洋葱多维思维学习平台 QQ群
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏开心洋葱吧~~~~~~~~~~~~~!

linux rsync(增量备份)安装配置部署详解

服务器 开心洋葱 2371次浏览 已收录 0个评论 手机上查看
文章索引目录
[隐藏]

linux rsync增量备份)安装配置部署详解

.下载安装rsync:

rsync是类unix系统下的数据镜像备份工具,从软件的命名上就可以看出来了——remote sync。它的特性如下:   
可以镜像保存整个目录树和文件系统。   
可以很容易做到保持原来文件的权限、时间、软硬链接等等。   
无须特殊权限即可安装。   
快速:第一次同步时 rsync 会复制全部内容,但在下一次只传输修改过的文件。rsync 在传输数据的过程中可以实行压缩及解压缩操作,因此可以使用更少的带宽。   
安全:可以使用rcp、ssh等方式来传输文件,当然也可以通过直接的socket连接。   
支持匿名传输,以方便进行网站镜象。

我们可以通过以下地址来获取rsync的安装包:

http://rsync.samba.org/ftp/rsync/rsync-3.0.9.tar.gz

目前最新的版本为rsync v3.0.9,好了,接下来我们来进行安装与配置。

安装Rsync

将下载好的rsync-3.0.9.tar.gz,放到:/RsyncDemo,或任意一个自定义的文件夹。
注意:需要在服务端和客户端分别安装,使用的包和命令都一样的。
[[email protected] RsyncDemo]# tar zxvf rsync-3.0.9.tar.gz
[[email protected] RsyncDemo]# cd rsync-3.0.9 #如果版本更新,请使用tab补全地址
[[email protected] rsync-3.0.9]# ./configure

1.1.出现“ rsync 3.0.9 configuration successful ”表示安装成功,如果不成功,则看前面差什么包就下载并安装什么包即可。

[[email protected] rsync-3.0.9]# make
[[email protected] rsync-3.0.9]# make install

1.1.无错误内容回显,表示安装成功,如果make那一步就失败,估计是你没有gcc编译环境或其他问题。

配置Rsync

1.1.1.1.一、服务端安装配置

[[email protected] rsync-3.0.9]# vi /etc/xinetd.d/rsync

1.1.default: off

1.1.description: The rsync server is a good addition to an ftp server, as it \

1.1.allows crc checksumming etc.

service rsync
{
disable = no #这里原本是yes,修改成no即可。
flags = IPv6
socket_type = stream
wait = no
user = root
server = /usr/bin/rsync
server_args = –daemon
log_on_failure += USERID
}
[[email protected] rsync-3.0.9]# chkconfig rsync on
[[email protected] rsync-3.0.9]# chkconfig rsync –list
rsync启用
[[email protected] rsync-3.0.9]# cd /etc/
[[email protected] etc]# touch rsync.conf
[[email protected] etc]# vi rsyncd.conf
uid = root #运行Rsync守护进程的用户
gid = root #运行Rsync守护进程的组
use chroot = no #不使用chroot
max connections = 5 #最大连接数为5
strict modes = yes #是否检查口令文件权限
port = 873 #默认端口

#模块名,可以建立多个,以[]开始
path = /RsyncDemo #待备份的目录,要绝对路径
comment = This is demo. #模块注释信息,顺便写什么
auth users = test #认证的用户名,如果无此行,则为匿名
uid = root
gid = root
secrets file = /etc/rsync.password #用户名、密码列表,需手动生成
ignore errors #忽略无关的IO错误
read only = no #非只读
list = no #不允许列文件

[[email protected] etc]# vi /etc/rsync.password #创建密码认证文件
test:password #在文件加入此行
[[email protected] etc]# chown root.root rsync.password #修改权限
[[email protected] etc]# chmod 400 rsync.password #修改权限
[[email protected] etc]# /usr/bin/rsync –-daemon #启动服务
[[email protected] etc]# vi /etc/rc.local #设置系统启动时,加载rsync服务
/usr/local/rsync –-daemon #在rc.local文件的最后一行加入此行信息即可
[[email protected] etc]# lsof -i :873 #检查服务是否启动,有如下内容表示已经启动
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
rsync 29673 root 4u IPv4 80341 0t0 TCP :rsync (LISTEN)
rsync 29673 root 5u IPv6 80342 0t0 TCP
:rsync (LISTEN)

1.1.1.1.二. 配置服务器端

首先编辑 /etc/rsyncd.conf 内容如下:
uid = nobody #进行备份的用户 nobody为任何用户
gid = nobody #进行备份的组 nobody为任何组
use chroot = no #不使用chroot
max connections = 10 #最大连接数
log file = /var/log/rsyncd.log #日志文件

[rsyncd] # 这里是认证的模块名
path = /home/test/ #参与同步的目录
ignore errors # 可以忽略一些无关的IO错误
read only = yes #只读
list = no #不允许列清单
anth users = root #认证的用户名
secrets file = /etc/rsyncd.secrets #密码文件存放地址

然后在/etc下面编辑一个rsyncd.secrets的密码存放文件
格式为
用户名:密码 如

root:75271.com

最后在server端将rsync以守护进程形式启动
命令为: rsync –daemon
rsync启动的端口为 873端口

1.1.1.1.三. 客户端的配置

在/etc下面编辑一个rsyncd.secrets的密码存放文件即可

执行命令为:
rsync -vzurtopg –progress –delete [email protected]::rsyncd /home/test –password-file=/etc/rsync.secret
参数 v 表示详细提示
z 表示压缩
u 表示只进行更新
topg 保持文件原有属性如属主、时间的参数
–progress 指显示
–delete 指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致
root 为用户名
@192.168.100.150为服务器IP
:后面的rsyncd为认证的模块名
/home/test 为备份到本地的目录名
–password-file=/etc/rsync.secret 制定密码存放位置的地址

可以编写脚本 rsync.sh

1.1.!/bin/sh

rsync -vzrtopg –progress –delete [email protected]::rsyncd /home/test –password-file=/etc/rsync.secret
然后将该脚本加入到/etc/crontab文件中 定时执行更新。

后面附上改命令option参数详解

1.1.1.1.Rsync命令参数详解

在对rsync服务器配置结束以后,下一步就需要在客户端发出rsync命令来实现将服务器端的文件备份到客户端来。rsync是一个功能非常强大的工具,其命令也有很多功能特色选项,我们下面就对它的选项一一进行分析说明。
Rsync的命令格式可以为以下六种:
  rsync [OPTION]… SRC DEST
  rsync[OPTION]… SRC [[email protected]]HOST:DEST
  rsync [OPTION]… [[email protected]]HOST:SRC DEST
  rsync [OPTION]… [[email protected]]HOST::SRC DEST
  rsync [OPTION]… SRC [[email protected]]HOST::DEST
  rsync [OPTION]… rsync://[[email protected]]HOST[:PORT]/SRC [DEST]  对应于以上六种命令格式,rsync有六种不同的工作模式:
  1)拷贝本地文件。当SRC和DES路径信息都不包含有单个冒号":"分隔符时就启动这种工作模式。如:rsync -a /data /backup
  2)使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。当DST路径地址包含单个冒号":"分隔符时启动该模式。如:rsync -avz *.c foo:src
  3)使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。当SRC地址路径包含单个冒号":"分隔符时启动该模式。如:rsync -avz foo:src/bar /data
  4)从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含"::"分隔符时启动该模式。如:rsync -av [email protected]::www /databack
  5)从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含"::"分隔符时启动该模式。如:rsync -av /databack [email protected]::www
  6)列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。如:rsync -v rsync://172.16.78.192/www
rsync参数的具体解释如下:
-v, –verbose 详细模式输出
-q, –quiet 精简输出模式
-c, –checksum 打开校验开关,强制对文件传输进行校验
-a, –archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
-r, –recursive 对子目录以递归模式处理
-R, –relative 使用相对路径信息
-b, –backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用–suffix选项来指定不同的备份文件前缀。
–backup-dir 将备份文件(如~filename)存放在在目录下。
-suffix=SUFFIX 定义备份文件前缀
-u, –update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)
-l, –links 保留软链结
-L, –copy-links 想对待常规文件一样处理软链结
–copy-unsafe-links 仅仅拷贝指向SRC路径目录树以外的链结
–safe-links 忽略指向SRC路径目录树以外的链结
-H, –hard-links 保留硬链结
-p, –perms 保持文件权限
-o, –owner 保持文件属主信息
-g, –group 保持文件属组信息
-D, –devices 保持设备文件信息
-t, –times 保持文件时间信息
-S, –sparse 对稀疏文件进行特殊处理以节省DST的空间
-n, –dry-run现实哪些文件将被传输
-W, –whole-file 拷贝文件,不进行增量检测
-x, –one-file-system 不要跨越文件系统边界
-B, –block-size=SIZE 检验算法使用的块尺寸,默认是700字节
-e, –rsh=COMMAND 指定使用rsh、ssh方式进行数据同步
–rsync-path=PATH 指定远程服务器上的rsync命令所在路径信息
-C, –cvs-exclude 使用和CVS一样的方法自动忽略文件,用来排除那些不希望传输的文件
–existing 仅仅更新那些已经存在于DST的文件,而不备份那些新创建的文件
–delete 删除那些DST中SRC没有的文件
–delete-excluded 同样删除接收端那些被该选项指定排除的文件
–delete-after 传输结束以后再删除
–ignore-errors 及时出现IO错误也进行删除
–max-delete=NUM 最多删除NUM个文件
–partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输
–force 强制删除目录,即使不为空
–numeric-ids 不将数字的用户和组ID匹配为用户名和组名
–timeout=TIME IP超时时间,单位为秒
-I, –ignore-times 不跳过那些有同样的时间和长度的文件
–size-only 当决定是否要备份文件时,仅仅察看文件大小而不考虑文件时间
–modify-window=NUM 决定文件是否时间相同时使用的时间戳窗口,默认为0
-T –temp-dir=DIR 在DIR中创建临时文件
–compare-dest=DIR 同样比较DIR中的文件来决定是否需要备份
-P 等同于 –partial
–progress 显示备份过程
-z, –compress 对备份的文件在传输时进行压缩处理
–exclude=PATTERN 指定排除不需要传输的文件模式
–include=PATTERN 指定不排除而需要传输的文件模式
–exclude-from=FILE 排除FILE中指定模式的文件
–include-from=FILE 不排除FILE指定模式匹配的文件
–version 打印版本信息
–address 绑定到特定的地址
–config=FILE 指定其他的配置文件,不使用默认的rsyncd.conf文件
–port=PORT 指定其他的rsync服务端口
–blocking-io 对远程shell使用阻塞IO
-stats 给出某些文件的传输状态
–progress 在传输时现实传输过程
–log-format=formAT 指定日志文件格式
–password-file=FILE 从FILE中得到密码
–bwlimit=KBPS 限制I/O带宽,KBytes per second
-h, –help 显示帮助信息
一般都使用azv选项


开心洋葱 , 版权所有丨如未注明 , 均为原创丨未经授权请勿修改 , 转载请注明linux rsync(增量备份)安装配置部署详解
喜欢 (0)
[开心洋葱]
分享 (0)
关于作者:
开心洋葱,开心洋葱头,水墨

您必须 登录 才能发表评论!

加载中……