drdb 基于文件系统同步
rsync 开源的多功能的、可实现全量、增量的本地或远程的数据同步工具。默认不加密,还可以删除,具备scp、cp、rm。
inotify实时增量备份,企业一般是rsync+inotify或rsync+sersync。虽然rsync可以增量备份,但企业一般不会采用这个功能,原因在于增量备份时会有比对,特别有业务的情况下,不能这样做会占用大量资源。
rsync 默认参数-avz -r --delete /目录后要带斜线,rsync区别与带不带/。一般都带代表只包括目录里的内容不含目录。
借助ssh通道传:rsync -avz /etc/hosts -e ‘ssh ’
-e表示需要借助的通道
v 表示verbose详细输出
z表示compress压缩传输
a--递归模式,保持文件时间,保持属主、权限、数组,显示同步过程进度等
rsync配置文件目录为/etc/rsyncd.conf默认不存在需要vi创建。
需手动写如下:
uid = rsync
gid = rsync
use chroot = no 不考虑安全性
max connections = 200
timeout = 300
pid file = /var/run/rsyncd.pid 进程号所在的文件
locak file = /var/run/rsync.lock 锁的机制
log file = /var/log/rsyncd.log
[oldboy]
path = /oldboy/ 相当于nfs的共享目录
ignore errors 传输过程中如遇到错误就忽略
read only = false
list = false 不允许列表
hosts allow = 0.0.0.0/0
hosts deny = 0.0.0.0/32
auth users = rsync_backup 虚拟用户认证
secrets file = /etc/rsync.password 把密钥写到文件里,不用每次传输要手敲密码
rsync --daemon以守护进程的方式启动
服务等操作如下:
mkdir /var/log/rsyncd.log -p
mkdir /var/run/rsync.lock
mkdir /oldboy -p
useradd rsync -s /sbin/nogin
chown -R rsync.rsync /oldboy/
echo 'rsync_backup:oldboy' >/etc/rsync.password虚拟用户的密码为oldboy
chmod 600 /etc/rsync.password
客户端:
echo 'oldboy' > /etc/rsync.password
chmod 600 /etc/rsync.password
rsync一般都是在客户端操作,服务端只是以daemon方式启动就行
rsync -avz rsync_backup@192.168.44.40::oldboy /data1 --password-file=/etc/rsync.password将服务端oldboy模块下的文件拷到本地/data1下,然后自动加载密码文件。
客户端排除--exclude排除不需要拷贝的,排除多个{x,y}
服务端排除就在配置文件最后加上exclude=a b 一般不在服务端配置操作因为需要重启服务或杀掉服务。
echo “/usr/bin/rsync --daemon” > /etc/rc.loal’
pkill rsync 杀服务的方法或者kill `cat /var/run/rsyncd.pid`
--delete无差异同步,比如删除不需要的可能客户端和服务端都能有,例如网站×××需要同时删除,但此动作非常危险,如果一旦客户端非人为删除或***删除了,就会导致备份的也没有了。用的时候要特别注意。
timeout连接超时时间,一旦连不上不要一直在那卡着。