Solr多核配置

大体步骤同单核配置一样,可以参考《Windows下安装配置Solr (tomcat7.0)》。

 

1. 为什么要采用多核

1.1. 多核的目的

 

Solr Multicore 的目的一个solr实例,可以有多个搜索应用。

既然可以把不同类型的数据放到同一index中,也可以使用分开的多indexes。

基于这一点,你只需知道如何使用多 indexes(实际上就是运行Solr的多实例)。

尽管如此,为每一个类型添加一个完整的Solr实例会显得太臃肿庞大。

Solr 引入了Solr core的概念,该方案使用一个Solr实例管理多个indexes,这样就有热点core(hot core)的重读(reloading)与交换(swap,通常是读index与写index交换),那么管理一个 core或index也容易些。
每个Solr core由它自己的配置文件和索引数据组成。在多core执行搜索和索引几乎和没有使用core一样。只是添加core的名字为各自不同的URL。

单core情况下的如下搜索:
http://localhost:9090/solr/select?q=dave%20matthews

在多core环境下,你可以通过如下方式访问一个名为mbartists的core:
http://localhost:9090/solr/core0/select?q=dave%20matthews
并非在URL中引入core name的参数名值对,而是用不同的context。这样就可以像在单core中执行你的管理任务,搜索,更新操作。

1.2. 为何使用多核

Solr实例支持多core比启用多index要好(do more)。多core同时解决了在生产环境下的一些关键需求: 
  (1) 重建索引
  (2) 测试配置变更 
  (3) 合并索引
  (4) 运行时重命名core
为何多core不是默认的?
多core是1.3版本中才加的,1.4后更成熟。

我们强烈建议你使用多core,既是你现在的solr.xml只配置了一个core,虽然会比单个索引稍复杂,但可以带来管理core上的好处。或许一天单个core可能最终RELOAD and STATUS命令,又或许单个core最终会被废禁。

多个core会是Solr将来支持大规模分布式索引的关键。因此,以后可以期待更多。
你可以得到更多的关于Solr的资料:http://wiki.apache.org/solr/CoreAdmin。

 

 

 

2. 怎么配置多核

 

2.1.. 在准备solr实例的运行目录时,有所变更

 

依然将 D:\apache\solrhome,作为solr实例的运行目录

把下载的solr包中的example/multicore文件夹下面的所有文件放入到D:\apache\solrhome里面。

 

2.2. 运行检测

Solr多核配置_第1张图片

 

Solr多核配置_第2张图片

 

 

 

3. 多核配置文件

3.1. 怎么添加新的核

 

3.1.1. 配置文件中先添加新核,solrhome目录下的solr.xml

  <cores adminPath="/admin/cores">
    <core name="core0" instanceDir="core0" />
    <core name="core1" instanceDir="core1" />
    <core name="liuweitoo" instanceDir="liuweitoo" />
  </cores>

 其中,name是核的名称,instanceDir是新实例对应的目录名,该实例的配置文件都要放在该目录下。

 

3.1.2. solrhome目录复制新的文件夹

Solr多核配置_第3张图片

 

 

3.2. 多核配置文件解析

 

 

3.2.1. solr.xml

 

(这只是默认文件,当然也可以指定别的文件),如:


<?xml version="1.0" encoding="UTF-8" ?> 
 <solr persistent="false">   
   <cores adminPath="/admin/cores"> 
     <core name="core0" instanceDir="core0" /> 
     <core name="core1" instanceDir="core1" /> 
   </cores> 
 </solr> 

这个文件是告诉solr应该加载哪些core,<cores>……</cores>里有 core0、core1。core0(可以类比以前的solr.home)/conf目录下有schema.xml与solrconfig.xml,可以把实际应用的/solr/conf/schema.xml复制过来(注意:solrconfig.xml不要复制)。

 

3.2.2. 启动tomcat,访问应用,就可以看到有 Admin core0 和 Admin core1


http://localhostd:9090/solr/
http://localhostd:9090/core0/admin/
http://localhostd:9090/core1/admin/
http://localhostd:9090/core1/admin/analysis.jsp

 

3.2.3. 一些关键的配置


Persistent="false"指明运行时的任何修改我们不做保存。如拷贝。如果你想保存从启动起的一些改动,那就把 persistent设置为true。

如果你的index策略是完成建index到一个纯净的core中然后交换到活动core 那么你绝对应该设为true。
sharedLib="lib"指明了所有core的jar文件的lib目录。

如果你有一个core有自己需要的jar文件,那么你可以把他们置入到core/lib目录。

例如:karaoke core 使用 Solr Cell来索引化富文本内容,因此那些用来解析和抽取富文本的jar文件被放到./examples/cores/karaoke/lib/.

 

 

 

 

 

 

 

你可能感兴趣的:(Solr多核配置)