Solr主从配置

来源:互联网 发布:unity3d 获取鼠标位置 编辑:程序博客网 时间:2024/05/21 22:34

1  概述

Solr是这样一个思路。首先至少有两个solr服务器,一个称为master(主服务),其余的一个或多个solr服务器被称为slave(附属服务)。每个slave轮询检查master的索引库版本,如果发现索引库版本有更新就会拉取master上的索引库:


关于solr的集群主要分为主从和SolrCloud两种主从,比较适合以读为主的场景。SolrCloud适合数据量大,时不时会有更新的情形。

关于更多介绍:http://wiki.apache.org/solr/SolrReplication

 

2  配置主从

2.1     Master配置

配置比较简单,修改Master solr配置目录下solrconfig.xml文件,新增:

<requestHandlername="/replication" class="solr.ReplicationHandler" >    <lst name="master">      <str name="replicateAfter">commit</str>      <str name="replicateAfter">startup</str>      <strname="confFiles">schema.xml,stopwords.txt,spellings.txt,synonyms.txt</str>    </lst> </requestHandler>


 

参数说明:

replicateAfter:指定一个字符串表示在什么动作发生之后触发动作。可选值:commit,、optimize、startup,也可以配置多个值,如果你配置为startup必须至少配置commit或optimize其中一项。

confFiles:指定需要复制的配置文件。可以指定多个配置文件用“,”隔开,默认复制conf目录下的配置文件。FileName:newFileName ,filename指的是master服务器上的名字,newFileName指的是复制到slave服务器上的名字。

backupAfter:用于指定何时产生一个备份。可选值:commit,、optimize、 startup。

maxNumberOfBackups:指定可以有多少份备份。

commitReserveDuration:如果你的索引库更新非常频繁而且网速又很慢,你可以指定这个参数增加他的时间值。默认为10秒。图3-1为官方对于参数解释的文档。

 

 

2.2     Slave配置

Slave可以配置多个,修改Master solr配置目录下solrconfig.xml文件,新增:

 

<requestHandler name="/replication"class="solr.ReplicationHandler" >      <lst name="slave">        <strname="masterUrl">http://localhost:8983/solr/solr_master</str>        <str name="pollInterval">00:00:20</str>      </lst> </requestHandler>

 

参数说明:

pollInterval 表示多久向master同步一次数据,数据格式{时}:{分}:{秒}。

masterUrl 即是Master机地址。

 

 

2.3     测试

以上配置完成后,启动solr

solr.cmd start

浏览器访问:http://localhost:8983/solr/

选择Master core后,往里面新增两条记录,然后再到slave里面查看,

 

可以查看到数据已经从master中同步过来了,查看同步记录状态,slave每隔20s去同步一次数据文件:

 


至此solr主从数据同步配置完成。

原创粉丝点击