你说海是黑色的 發表於 2023-8-22 00:00:00

sersync文件实时同步

<p>门户网站一般使用一台cms来生成静态文件,cms同步文件到几台服务器上提供用户访问,现在有些使用sersync实时同步到多台web服务器上,有些站点则使用rsync+inotify来同步文件,还有各种方法,这种就不列举了,这边看下sersync的安装配置.</p>
<p><strong>sersync介绍</strong></p>
<p>sersync主要用于服务器同步,web镜像等功能。基于boost1.43.0,inotify api,rsync command.开发。目前使用的比较多的同步解决方案是inotify-tools+rsync ,另外一个是google开源项目Openduckbill(依赖于inotify- tools),这两个都是基于脚本语言编写的。相比较上面两个项目,本项目优点是:</p>
<ul>
<li>    sersync是使用c++编写,而且对linux系统文件系统产生的临时文件和重复的文件操作进行过滤(详细见附录,这个过滤脚本程序没有实现),所以在结合rsync同步的时候,节省了运行时耗和网络资源。因此更快。</li>
</ul>
<ul>
<li>    相比较上面两个项目,sersync配置起来很简单,其中bin目录下已经有基本上静态编译的2进制文件,配合bin目录下的xml配置文件直接使用即可。</li>
</ul>
<ul>
<li>    另外本项目相比较其他脚本开源项目,使用多线程进行同步,尤其在同步较大文件时,能够保证多个服务器实时保持同步状态。</li>
</ul>
<ul>
<li>    本项目有出错处理机制,通过失败队列对出错的文件重新同步,如果仍旧失败,则按设定时长对同步失败的文件重新同步。</li>
</ul>
<ul>
<li>    本项目自带crontab功能,只需在xml配置文件中开启,即可按您的要求,隔一段时间整体同步一次。无需再额外配置crontab功能。</li>
</ul>
<ul>
<li>    本项目socket与http插件扩展,满足您二次开发的需要。</li>
</ul>
<p><strong>下载sersync</strong></p><pre class="brush:bash;toolbar:false"># wget http://tar.766.com/sersync2.5.4_64bit_binary_stable_final.tar.gz</pre><p><strong>安装sersync</strong></p><pre class="brush:bash;toolbar:false"># tar -xzvf sersync2.5.4_64bit_binary_stable_final.tar.gz  -C /usr/local/sersync</pre><p><strong>配置sersync</strong></p><pre class="brush:bash;toolbar:false"># vim confxml.xml

&lt;filter start="false"&gt;                                                               #关闭文件过滤监控
&lt;inotify&gt;                                                                            #监控参数
    &lt;modify start="true"/&gt;                                                           #允许修改监控
&lt;/inotify&gt;                      
&lt;sersync&gt;                                                                            #监控参数
     &lt;localpath watch="/data/site/"&gt;                                                  #监控目录
           &lt;remote ip="192.168.1.2" name="psn_ttlsa_com"/&gt;                             #同步到远程主机的rsync 块 psn_html下
     &lt;/localpath&gt;
    &lt;rsync&gt;                                                                          #rsync参数
      &lt;auth start="true" users="root" passwordfile="/etc/rsync.pas"/&gt;                #用户名密码
      &lt;timeout start="false" time="300"/&gt;                                            #超时设置
    &lt;/rsync&gt;
    &lt;failLog path="/tmp/rsync_fail_log.sh" timeToExecute="30"/&gt;                      #同步失败日志脚本(30分钟后会重新同步)
&lt;/sersync&gt;</pre><p><strong>启动sersync</strong></p><pre class="brush:bash;toolbar:false">/usr/local/sersync/sersync2 -o ./confxml.xml -n 20 -d
-o                                                                                  #指定配置文件
-n                                                                                  #启动线程数量
-d                                                                                  #daemon方式启动</pre><p>在/data/site下创建、删除、修改文件都会实时同步到192.168.1.2的rsync模块为psn_ttlsa_com的站点上.sersync安装在cms上。其他web服务器需要安装rsync服务器.</p>
<p> </p>
頁: [1]
查看完整版本: sersync文件实时同步