rsync远程同步

rsync远程同步

一、概览

1、关于rsync

一款快速增量备份工具

  • Remote Sync远程同步
  • 支持本地复制,或者与其他SSH、rsync主机同步
  • 官方网站: htp://rsync.samba.org

2、配置rsync源服务器

rsync同步源

  • 指备份操作的远程服务器,也称为备份源

mark

3、配置rsync源

1、基本思路

  • 建立rsyncd.conf配置文件、独立的账号文件
  • 启用rsync的–daemon模式

2、应用示例

  • 用户backuper,允许下行同步
  • 操作的目录为/var/www/html/

3、配置文件rsyncd.conf

  • 需手动建立,语法类似于Samba配置
  • 认证配置auth users、secrets file,不加则为匿名

4、rsync账号文件

  • 采用“用户名:密码”的记录格式,每行一个用户记录
  • 独立的账号数据,不依赖于系统账号

5、启用rsync服务

  • 通过–daemon独自提供服务

4、rsync命令的用法

rsync [选项] 原始位置 目标位置

●常用选项

  • -a: 归档模式,递归并保留对象属性,等同于-rlptgoD
  • -V:显示同步过程的详细(verbose) 信息
  • -Z: 在传输文件时进行压缩(compress)
  • -H:保留硬连接文件
  • -A:保留ACL属性信息
  • -delete: 删除目标位置有而原始位置没有的文件
  • –checksum: 根据对象的校验和来决定是否跳过文件

二、实验

实验一、rsync手动同步及自动同步

1、实验准备
服务端IP:192.168.150.154

客户端IP:192.168.150.156
2、关闭防火墙(两台)
iptables -F

setenforce 0

systemctl stop firewalld
3、配置rsync源服务器(服务端)
vim /etc/rsyncd.conf          ##修改内容如下所示

uid = nobody    #用户名
gid = nobody    #组信息
use chroot = yes
port 873
log file = /var/log/rsyncd.log
pid file = /var/run/rsyncd.pid
hosts allow = 192.168.150.0/24

[wwwroot]                             ##共享站点
path = /var/www/html        ##站点目录
comment = www.kgc.cn     ##域名信息
read only = yes                     ##只读
dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2   ##文件类型
auth users = backuper                       ##管理员用户名
secrets file = /etc/rsyncd_users.db  ##用户名密码文件



vim /etc/rsyncd_users.db      ##配置文件修改如所示

backuper:abc123                    ##用户名和密码

chmod 600 /etc/rsyncd_users.db     ##给文件添加权限

rsync --daemon                     ##开启服务

netstat -natp | grep rsync   ##查看服务
4、服务端安装apache服务(服务端)
yum install httpd -y

cd /var/www/html/

vim index.html  ##创建网页文件
5、客户端同步(客户端)
格式一:

rsync -avz backuper@192.168.150.154::wwwroot /opt/       //密码abc123

##文件同步成功

格式二:

rsync -avz rsync://backuper@192.168.150.154/wwwroot /opt/   //密码abc123

##文件同步成功
6、rsync免交互(客户端)
vim /etc/server.pass   ##编辑配置文件

abc123                          ##文件中保存密码

chmod 600 /etc/server.pass      ##添加权限

rsync -az --delete --password-file=/etc/server.pass backuper@192.168.150.154::wwwroot /opt/abc

实验二、rsync实时同步

1、实验准备
服务端IP:192.168.150.156

客户端IP:192.168.150.154
2、安装apache服务(服务端)
yum install httpd -y
3、删除原有服务器的主机(客户端)
rm -rf *   ##删除所有网页文件
4、编辑配置文件(客户端)
vim /etc/sysctl.conf

fs.inotify.max_queued_events = 16384
fs.inotify.max_user_instances = 1024
fs.inotify.max_user_watches = 1048576

sysctl -p           ##启动
5、安装inotifi-tools工具(服务端)
cd /opt

tar zxvf inotify-tools-3.14.tar.gz 

cd inotify-tools-3.14/

yum install gcc gcc-c++ make -y              ##安装工具包

./configure

make && make install                              ##编译并安装

inotifywait -mrq -e modify,create,move,delete /var/www/html/

##执行监控 -m:持续进行监控  -r:递归监控所有子对象  -q:简述输出信息 -e:指定要监控的事件类型



'//此时是一个持续性的状态' 另外在开启一个新的终端设置 监控的路径是/var/www/html 

cd /var/www/html/

touch index.txt                     ##在目录中创建文件

inotifywait -mrq -e modify,create,move,delete /var/www/html/

##可以看出都是可以监控到的内容



##第一台服务器主机可以看到内容如下所示

/var/www/html/ CREATE index.txt
6、编写触发式同步脚本(服务端)
vim inotfiy.sh

#!/bin/bash
INOTIFY_CMD="inotifywait -mrq -e modify,create,attrib,move,delete /var/www/html/"
RSYNC_CMD="rsync -azH --delete --password-file=/etc/server.pass /var/www/html/ backuper@192.168.150.156::wwwroot/"
$INOTIFY_CMD | while read DIRECTORY EVENT FILE
do
    if [ $(pgrep rsync | wc -l) -le 0 ] ; then
        $RSYNC_CMD
    fi
done

chmod +x inotfiy.sh        ##增加执行权限

##上述脚本用来检测本机/var/www/html目录的变动情况,一旦有更新触发rsync同步操作,上传备份至服务器192.168.150.156/var/www/html目录下。
7、设置服务器只读模式关闭(客户端)
vim /etc/rsyncd.conf 

read only = no    ##要是开了只读的配置,就不能写入
8、增加权限(服务端和客户端)
chmod 777 /var/www/html/    ##服务端和客户端都要设置权限
9、执行脚本启动监控(服务端)
./inotfiy.sh

##打开源服务器的另一个窗口在/var/www/html目录下创建新的文件

touch 1.txt

touch 2.txt

touch 3.txt
10、查看服务器的变化情况(客户端)
ls /var/www/html/

##已经同步成功,实验结束
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值