Solr主从配置

x33g5p2x  于2021-12-20 转载在 其他  
字(1.7k)|赞(0)|评价(0)|浏览(429)

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主从数据同步配置完成。

相关文章