zoukankan      html  css  js  c++  java
  • linux Sersync 参数说明

    Sersync 的可选功能是通过 xml 配置文件来实现的,下面来为大家解释该文件!

    在该文件中,使用<!--中间是注释内容-->的方式去注释信息,注意不是我们平时#

    [root@SERSYNC sersync]# cat conf/confxml.xml -n

    1<?xml version="1.0" encoding="ISO-8859-1"?>

    2<head version="2.5">

    3    <host hostip="localhost" port="8008"></host>  #hostip 与 port 是针对插件的保留字段,对于

    同步功能没有任何作用,保留默认即可。

    4    <debug start="false"/>  #该行为 Debug 开启开关。true 为开启 debug 模式,会在 sersync 正在

    运行的控制台,打印 inotify 事件与 rsync 同步命令,生产环境一般不开启。

    5    <fileSystem xfs="false"/>#对于 XFS 文件系统的用户,需要将这个选项开启,才能使 sersync 正常工

    对于 sersync 监控的文件,会默认过滤系统的临时文件(以“.”开头,以“~”结尾),除了这些文件外,

    在 6-11 行中,我们还可以自定义其它需要过滤的文件。

    通过将 start 设置为 true 后可开启过滤功能,在 exclude 标签中可使用正则表达式。默认给出的两个例子

    分别是过滤以“.gz”结尾的文件与过滤监控目录下的 info 路径(监控路径/info/*),可以根据需求自己添加。

    但在开启的时候,自己一定要测试下,如果正则表达式出现错误,控制台会有相应提示。相比较使

    用 Rsync 的 exclude 功能,被过滤的路径,不会加入监控,大大减少 Rsync 同步的通讯量

    6    <filter start="false">

    7<exclude expression="(.*).svn"></exclude>

    8<exclude expression="(.*).gz"></exclude>

    9<exclude expression="^info/*"></exclude>

    10<exclude expression="^static/*"></exclude>

    11   </filter>

    第 12-23 行用来定义 inotify 监控参数,我们可以根据项目的特点来优化 Sersync。

    通讯。因为拷贝文件到监控目录会产生 create 事件与 close_write 事件,所以如果关闭 create 事件,只监控

    文件拷贝结束时的事件 close_write,同样可以实现文件完整同步。

    注意:要使得 createFolder 保持为 true,如果将 createFolder 设为 false,则不会对产生的目录进行监控, 该目录下的子文件与子目录也不会被监控,所以除非特殊需要,请开启。默认情况下对创建文件(目录)事件 与删除文件(目录)事件都进行监控,如果项目中不需要删除远程目标服务器的文件(目录),则可以将 delete 参 数设置为 false,则不对删除事件进行监控。

    12   <inotify>

    13<delete start="true"/>

    14<createFolder start="true"/>

    15<createFile start="false"/>

    16<closeWrite start="true"/>

    17<moveFrom start="true"/>

    18<moveTo start="true"/>

    19<attrib start="false"/>

    20<modify start="false"/>

    21   </inotify>

    23   <sersync>

    第 24-28 行用来定义所要同步和监控的目录文件。

    /opt/tongbu 目录为 sersync 主服务器本地待同步的目录,ip=“192.168.8.39”为从服务器的 ip 地址,如果

    有多个服务器,依次列出来即可。name=“tongbu”,这里的 tongbu 为 rsyncd.conf 中的模块名字,即中

    括号中的名称。

    24<localpath watch="/opt/tongbu">

    25   <remote ip="127.0.0.1" name="tongbu1"/>

    26   <!--<remote ip="192.168.8.39" name="tongbu"/>-->

    27   <!--<remote ip="192.168.8.40" name="tongbu"/>-->

    28</localpath>

    第 29-35 行用来定义 rsync 的命令参数

    在 commonParams 项,我们可以自定义 rsync 的同步参数,默认是-artuz,auth start=“false”设置为 true

    的时候,使用 rsync 的认证模式传送,需要配置 user 与 passwordfile(-password-file=/etc/rsync.pas)来

    使用。userDefinedPort 当远程同步目标服务器的 rsync 端口不是默认端口的时候使用(-port=874)。timeout

    设置 rsync 的 timeout 事件(-timeout=100)。<ssh start=”false”/>如果开启表示 ssh 使用 rsync -e ssh

    的方式进行传输。

    29<rsync>

    30   <commonParams params="-artuz"/>

    31   <auth start="false" users="root" passwordfile="/etc/rsync.pas"/>

    32   <userDefinedPort start="false" port="874"/><!-- port=874 -->

    33   <timeout start="false" time="100"/><!-- timeout=100 -->

    34   <ssh start="false"/>

    35</rsync>

    第 36 行用来定义失败日志脚本配置

    (timeToExecute 进行设置)执行该脚本再次重新传送,然后清空该脚本。可以通过 path 来设置日志路径

    36<failLog path="/tmp/rsync_fail_log.sh" timeToExecute="60"/><!--default every 60mins execut e once-->

    第 37-42 行用来定义 Crontab 定期整体同步功能

    Crontab 可以对监控路径与远程目标主机每隔一段时间进行一次整体同步,可能由于一些原因两次失败重传都 失败了,这个时候如果开启了 crontab 功能,还可以进行一次保证各个服务器文件一致,如果文件量比较大, crontab 的时间间隔要设的大一些,否则可能增加通讯开销,schedule 这个参数是设置 crontab 的时间间隔, 默认是 600 分钟。

    如果开启了 filter 文件过滤功能,那么 crontab 整体同步也需要设置过滤,否则虽然实时同步的时候文件被过

    滤了,但 crontab 整体同步的时候,如果不单独设置 crontabfilter,还会将需过滤的文件同步到远程从服务器,

    crontab 的过滤正则与 filter 过滤的不同,也给出了两个实例分别对应与过滤文件与目录,总之如果同时开启

    了 filter 与 crontab,则要开启 crontab 的 crontabfilter,并按示例设置使其与 filter 的过滤一一对应。

    37<crontab start="false" schedule="600"><!--600mins-->

    38   <crontabfilter start="false">

    39<exclude expression="*.php"></exclude>

    40<exclude expression="info/*"></exclude>

    41   </crontabfilter>

    42</crontab>

    43<plugin start="false" name="command"/>

    44   </sersync>

    从 46 行到行尾,都是插件的相关信息。当 plugin 标签设置为 true 时候,在同步文件或路径到远程服务器之

    后,会调用插件。通过 name 参数指定需要执行的插件。目前支持的有 command、refreshCDN、socket、

    http 四种插件。其中,http 插件目前由于兼容性原因已经去除,以后会重新加入。

    46   <plugin name="command">

    47<param prefix="/bin/sh" suffix="" ignoreError="true"/><!--prefix /opt/tongbu/mmm.sh suffix-

    ->

    48<filter start="false">

    49   <include expression="(.*).php"/>

    50   <include expression="(.*).sh"/>

    51</filter>

    52   </plugin>

    第 54-58 行为插件 socket 的相关配置

    socket 插件,开启该模块,则向指定 ip 与端口发送 inotify 所产生的文件路径信息

    54   <plugin name="socket">

    55<localpath watch="/opt/tongbu">

    56   <deshost ip="192.168.138.20" port="8009"/>

    57</localpath>

    58   </plugin>

    第 59-65 行为插件 refreshCDN 的相关配置

    refreshCDN 用来在同步过程中将文件发送到目地服务器后,刷新 cdn 接口。如果不想使用,则将 start 属性                 48

    设为 false 即可。该模块根据 chinaCDN 的协议,进行设计,当有文件产生的时候,就向 cdn 解耦发送需要刷 新的路径为止。其中 localpath watch=“/data0/htdocs/cms.xoyo.com/site/”是需要监控的目录。cdinfo 标签指定了 cdn 接口的域名,端口号,以及用户名与密码。sendurl 标签是需要刷新的 url 的前缀。regexurl 标 签中,regex 属性为 true 时候,使用 match 属性的正则语句匹配 inotify 返回的路径信息,并将正则匹配到的 部分作为 url 一部分

    下面配置文件自带的意思为,如果产生文件事件为:

    /data0/htdoc/cms.xoyo.com/site/jx3.xoyo.com/image/a/123.txt

    经过上面的 match 正则匹配后,最后刷新的路径是:http://pic.xoyo.com/cms/a/123.txt

    如果 regex 属性为 false,最后刷新的路径就是:http://pic.xoyo.com/cms/jx3.xoyo.com/images/a/123.txt

    59   <plugin name="refreshCDN">

    60<localpath watch="/data0/htdocs/cms.xoyo.com/site/">

    61   <cdninfo domainname="ccms.chinacache.com" port="80" username="xxxx" passwd="xxxx"

    />

    62   <sendurl base="http://pic.xoyo.com/cms"/>

    63   <regexurl regex="false" match="cms.xoyo.com/site([/a-zA-Z0-9]*).xoyo.com/images"/>

    64</localpath>

    65   </plugin>

    66</head>

    这里列举,如何单独去运行插件

    插件也可以单独使用,即不对远程目标机进行同步,直接调用插件。

    只调用 command 插件

    1[root@SERSYNC ~]# sersync -d -m command

    只调用 refreshCDS 插件

    1[root@SERSYNC ~]# sersync -d -m refreshCDN

    只调用 socket 插件

    1[root@SERSYNC ~]# sersync -d -m socket

    只调用 http 插件

    1[root@SERSYNC ~]# sersync -d -m http

  • 相关阅读:
    selenium-Selense、脚本语法
    selenium常用命令
    百度自动化测试脚本制作
    day2
    day1
    Python核心编程3-正则表达式
    redis
    mysql与系统优化
    mysql之mha高可用及读写分离
    作业一
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11327482.html
Copyright © 2011-2022 走看看