使用rsync实现文件备份同步

Linux评论阅读模式

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

二. 安装
服务端和客户端安装rsync
yum -y install rsync
也可以源码安装
rsync下载地址:http://rsync.samba.org/
./configure
make && make install
但是需要注意的是必须在服务器A和B上都安装rsync,其中A服务器上是以服务器模式运行rsync,而B上则以客户端方式运行rsync。这样在web服务器A上运行rsync守护进程,在B上定时运行客户程序来备份web服务器A上需要备份的内容。

三. 服务端配置

cat  /etc/rsyncd.conf
#[globale]
strict modes = yes
port = 873
uid = nobody
gid = nobody
user chroot = no
max connections = 5                 #同时的最大连接数
timeout = 600
pid file = /var/run/rsyncd.pid      #进程的pid存放文件位置
lock file = /var/run/rsyncd.lock    #lock文件位置
log file = /var/log/rsyncd.log      #日志文件位置
 
[testdata]                          #建立一个备份名,客户端通过该名称指定具体的备份位置
path=/data/test/img                 #备份文件存放的目录位置
ignore errors
read only = no
list = no
hosts allow = 106.xxx.xxx.xxx       #允许客户端B地址
auth users = test                   #允许那些用户,这里的用户test的信息存放在/etc/rsyncd.password
secrets file = /etc/rsyncd.password #指定允许的用户和用户密码

建立/etc/rsyncd.password文件

cat /etc/rsyncd.password
test:123456

修改防火墙策略,允许873端口(tcp/udp)

iptables -A INPUT -s 106.xxx.xxx.xxx -p tcp -m state --state NEW -m tcp --dport 873 -j ACCEPT
service iptables save

启动服务器端

/usr/bin/rsync --daemon --config=/etc/rsyncd.conf

开机自启动

echo '/usr/bin/rsync --daemon --config=/etc/rsyncd.conf' >> /etc/rc.local

四. 客户端配置

/usr/bin/rsync -avzP --delete  --progress --password-file=/etc/rsyncd.password test@服务端ip::test /data/backup/img

rsync参数
-a –archive归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD
-r –recursive 对子目录以递归模式处理
-l –links 保留软链
-p –perms 保持文件权限
-t –times 保持文件时间信息
-g –group 保持文件属组信息
-o –owner 保持文件属主信息
-D –devices 保持设备文件信息
-z –compress 对备份的文件在传输时进行压缩处理
-P –partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输
-v –verbose 详细模式输出
-e –rsh=COMMAND 指定替代rsh的shell程序
-u –update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)
–progress 显示备份过程
–delete 是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。

http://www.linuxeye.com/configuration/729.html

 
  • 本文由 yeho 发表于 2012-07-31
  • 转载请务必保留本文链接:https://linuxeye.com/152.html
  • Rsync
  • 文件备份
Linux

Nginx反向代理永久性缓存

Nginx缓存简介 Nginx缓存方式有两种: 永久性的缓存:这种缓存若不手动删除,该缓存文件会一直生效,因此,永久缓存只是用于缓存网站中几乎不会更改的内容; 临时缓存:这种缓存是根据请求连接进行哈希...
Linux

Consul集群配置

consul原理 上图是官网提供的一个事例系统图,图中的Server是consul服务端高可用集群,Client是consul客户端。consul客户端不保存数据,客户端将接收到的请求转发给响应的Se...
匿名

发表评论

匿名网友
确定

拖动滑块以完成验证