Solr是这样一个思路。首先至少有两个solr服务器,一个称为master(主服务),其余的一个或多个solr服务器被称为slave(附属服务)。每个slave轮询检查master的索引库版本,如果发现索引库版本有更新就会拉取master上的索引库:
关于solr的集群主要分为主从和SolrCloud两种主从,比较适合以读为主的场景。SolrCloud适合数据量大,时不时会有更新的情形。
关于更多介绍:http://wiki.apache.org/solr/SolrReplication
配置比较简单,修改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为官方对于参数解释的文档。
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机地址。
以上配置完成后,启动solr
solr.cmd start
浏览器访问:http://localhost:8983/solr/
选择Master core后,往里面新增两条记录,然后再到slave里面查看,
可以查看到数据已经从master中同步过来了,查看同步记录状态,slave每隔20s去同步一次数据文件:
至此solr主从数据同步配置完成。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/vtopqx/article/details/74913464
内容来源于网络,如有侵权,请联系作者删除!