设为首页 收藏本站
查看: 893|回复: 0

[经验分享] 基于solr的网站索引架构(一)

[复制链接]

尚未签到

发表于 2016-12-15 08:44:25 | 显示全部楼层 |阅读模式
  关于solr的介绍和参数说明等,可参与网上资料。我这里就只分享下我在项目中使用solr的一些学习心得。
  版本:由于使用到 中文分词IKanalry ,是solr4.0才有的新特性,所以使用solr4.0。
  solr 官方地址:http://lucene.apache.org/solr/
  (备注,项目使用时solr4.0正式版本还没有出来,所有我使用的solr4.0 Beta版本)
  IKAnalyzer 中文分词,需要IKAnalyzer4.1.jar支持,需要在solrconfig.xml中配置jar包路径
  solr的安装:
  1:准备一个tomcat作为solr的服务器,将solr解压,找到dist文件中的apache-solr-4.0.0.war,拷贝到webapps目录下。
  2:任意选择一个目录作为solr/home目录,solr/home里是放置你的多个core文件(可先从example\multicore下拷贝example),建立独立搜索规则。我同时在slor/home下建立了一个lib目录,用来存放IKAnalyzer的jar包和配置文件。还有solr.xml文件,最后solr/home的结构图如下:
  
DSC0000.jpg
 core0,core1.core2.core3表示了我建立了4套不同的搜索规则。项目各不干扰。然后将4套搜索配置到solr.xml中,代码如下:

  <cores adminPath="/admin/cores" defaultCoreName="collection1" host="${host:}" hostPort="${jetty.port:}" zkClientTimeout="${zkClientTimeout:15000}">
<core name="core0" instanceDir="core0" />
<core name="core1" instanceDir="core1" />
<core name="core2" instanceDir="core2" />
<core name="core3" instanceDir="core3" />
</cores>
  如上solr/home建立完成
  3: 运行solr的方法
  1).在当前路径运行tomcat (索引文件在Solr.Home下推荐) 如:
  E:\solr-tomcat>E:\apache-tomcat-6.0.29\bin\startup.bat
  注意如果你不将apache-solr-1.4.1.war 拷贝到 tomcat的webapps 下。
  你也可以在E:\apache-tomcat-6.0.29\conf\server.xml 添加 <Context docBase="E:/apache-tomcat-6.0.29/webapps/solr.war" debug="0" path="/solr01" /> 
  来告诉Tomcat 你的网站在哪里
    2).在tomcat的conf文件夹建立Catalina文件夹,然后在Catalina文件夹中在建立localhost文件夹,在该文件夹下面建立solr.xml
      <Context docBase="D:/Tomcat7.0-solr/webapps/solr" debug="0" crossContext="true"> 
                   <Environment name="solr/home" type="java.lang.String" value="D:/Tomcat7.0-solr/solrHome" override="true"/> 
                </Context> 
      然后直接双击 startup.bat 运行Tomcat 索引文件在 %Tomcat_Home%\Bin下。
                docBase为操作步骤1的地址(当然如果,war被访问会自动解压为solr文件夹,就可以直接配置到solr目录下),Environment 的Value为步骤2中的solr/home目录。
  3).E:\apache-tomcat-6.0.29\webapps\solr\WEB-INF\Web.xml设置
  <env-entry>
  <env-entry-name>solr/home</env-entry-name>
  <env-entry-value>E:/solr-tomcat/solr</env-entry-value>
  <env-entry-type>java.lang.String</env-entry-type>
  </env-entry>
  然后直接双击 startup.bat 运行Tomcat 索引文件在 %Tomcat_Home%\Bin下
  以上操作引子网上,我使用的是方法2)。
  从solr- -4.4.0 \example\lib\ext复制所有的jar到 apache-tomcat-7.0.42 /lib下
  完成以上步骤后,启动tomcat访问http://192.168.1.83:8089/solr 不出意外就已经成功启动solr服务了
  solrconfig.xml文件介绍:
  由于引入了IKAnalyzer的jar包,所以在solrconfig.xml也要做配置。参考solr中的其他代码,如下配置  <lib dir="../lib/" regex=".*\.jar" /> 。

  schema.xml文件介绍:
  配置了索引字段和内容,会和具体业务相关。
  IKAnalyzer在schema.xml中配置如下(text_cn的类型将支持中文分词):

<fieldType name="text_cn" class="solr.TextField" positionIncrementGap="100">  
<!--<analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/> -->  
<analyzer type="index">  
<tokenizer class="org.wltea.analyzer.solr.IKTokenizerFactory" isMaxWordLength="false"/>  
<filter class="solr.StopFilterFactory" ignoreCase="true" words="stopwords.txt" enablePositionIncrements="true" />  
<filter class="solr.StandardFilterFactory"/>  
<filter class="solr.RemoveDuplicatesTokenFilterFactory"/>  
</analyzer>  
<analyzer type="query">   
<tokenizer class="org.wltea.analyzer.solr.IKTokenizerFactory" isMaxWordLength="false"/>  
<filter class="solr.StopFilterFactory" ignoreCase="false" words="stopwords.txt" enablePositionIncrements="true" />  
<filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" ignoreCase="true" expand="true"/>  
<filter class="solr.StandardFilterFactory"/>  
<filter class="solr.RemoveDuplicatesTokenFilterFactory"/>  
</analyzer>   
</fieldType>  
  完成solr的安装和配置后,接下来就是solr索引的生成和solr在项目中的使用。嗯,再去梳理下,下一篇再贴出代码介绍。
  附件为IKAnalyzer的配置

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-314448-1-1.html 上篇帖子: solr cache使用分析和介绍 下篇帖子: solr和lucence好的学习资料
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表