博客
关于我
rsync远程同步
阅读量:511 次
发布时间:2019-03-07

本文共 1711 字,大约阅读时间需要 5 分钟。

第十二章 rsync 远程同步

实验拓扑图

此处应插入实验拓扑图图片描述。图片展示了北京和深圳两台服务器的网络架构,采用VPN专用线路实现物理互联。

实验环境描述

某公司在深圳和北京各部署了一台网站服务器,分别负责南北大区内的客户访问。此两台服务器的网站文档需保持一致,且同步链路已通过VPN专用线路完成。

项目需求

  • 服务器A(北京):rsync发起端,传输源目录为 /var/www/html
  • 服务器B(深圳):rsync远程服务器,接收目录为 /var/www/html
  • 同时结合inotify机制,实现触发式的上传同步,确保两地站点的网页文档保持一致。

推荐操作步骤

  • 配置rsync服务器(深圳,服务器B)。
  • 在北京(服务器A)配置inotify机制,实现实时同步。
  • 实验步骤

    一、配置rsync服务器(深圳,服务器B)

  • 安装rsync:
    yum install rsync
  • 配置rsync文件:打开 /etc/rsyncd.conf,添加如下内容:
    [DEFAULT]log file /var/log/rsync.log
  • _fit,译&;能量条使用随机数secanonize 工作方式: Parallelsocket_options: SO_SNDTIMEO | SO_RCVTIMEOiction: losemax connections: 100

    保存后测试配置是否正确:

    rsync --version

    3. 配置rsync用户数据库:

    vim /etc/rsyncd_users.db

    添加一个用户并设置密码:

    user1:YourPasswordHere

    修改权限:

    chmod 600 /etc/rsyncd_users.db

    创建同步目录并设置权限:

    mkdir -p /var/www/htmlchown -R rsyncuser:rsyncgrp /var/www/html

    4. 启动rsync服务:

    rsync --daemon

    #### 二、基于inotify的实时同步(北京,服务器A)1.调整inotify内核参数:修改`/etc/sysctl.conf`,添加以下项:

    net.inotify.max_user_instances=100net.inotify.max_files=500

    应用参数:

    sysctl -p

    2.安装inotify-tools:

    tar zxvf /path/to/inotify-tools-3.x.x.tar.gz -C /optcd /opt/inotify-tools-3.x.x./configure && make && make install

    安装完成后,启动相关服务:

    systemctl start inotifydsystemctl enable inotifyd

    3. 编写同步脚本:

    vim /opt/inotify_rsync.sh

    脚本内容如下:

    #!/bin/bashsource /home/user/.bashrcrsync -avz --delete --update --timeout 30

    --excludeFromFile /etc/rsyncd_users.db
    rsync@192.168.100.20:/var/www/html/

    DOS 脚本示例(可根据实际需求调整):

    @echo offcall ssh root@192.168.100.20 /opt/inotify_rsync.sh

    4. 免交互式身份验证:- 生成SSH公钥对:  ```  ssh-keygen -t rsa  ```- 将公钥添加到服务器B:  ```  ssh-copy-id -i ~/.ssh/id_rsa root@192.168.100.20  ```5. 后台运行脚本:

    sh /opt/inotify_rsync.sh &

    ### 验证- 确认rsync服务是否运行:

    ss rsync:192.168.100.20

    - 检查是否有文件传输发生:

    tail -f /var/log/rsync.log

    转载地址:http://rfbnz.baihongyu.com/

    你可能感兴趣的文章
    Nessus漏洞扫描教程之配置Nessus
    查看>>
    Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
    查看>>
    Netpas:不一样的SD-WAN+ 保障网络通讯品质
    查看>>
    Netty WebSocket客户端
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>