zoukankan      html  css  js  c++  java
  • 二、Solr单机版的搭建

    1.1. 运行环境

    solr 需要运行在一个Servlet容器中,Solr4.10.3要求jdk使用1.7以上,Solr默认提供Jettyjava写的Servlet容器),本次使用Tocmat作为Servlet容器,环境如下:

    SolrSolr4.10.3

    Jdkjdk1.7.0_72

    Tomcatapache-tomcat-7.0.53

    1.2. Solr的安装

    第一步:安装linuxjdktomcat

    [root@bogon ~]# tar -zxf apache-tomcat-7.0.47.tar.gz 
    [root@bogon ~]# ll
    total 8048
    drwxr-xr-x. 9 root root    4096 Sep 10 17:55 apache-tomcat-7.0.47
    -rw-r--r--. 1 root root 8234674 Oct 27  2013 apache-tomcat-7.0.47.tar.gz
    [root@bogon ~]# mkdir /usr/local/solr
    [root@bogon ~]# cp apache-tomcat-7.0.47 /usr/local/solr/tomcat
    cp: omitting directory `apache-tomcat-7.0.47'
    [root@bogon ~]# cp apache-tomcat-7.0.47 /usr/local/solr/tomcat -r
    [root@bogon ~]# cd /usr/local/solr/
    [root@bogon solr]# ll
    total 4
    drwxr-xr-x. 9 root root 4096 Sep 10 17:56 tomcat

    第二步:把solr的压缩包上传到服务器。并解压。

    第三步:把/root/solr-4.10.3/dist/solr-4.10.3.war包部署到tomcat下。并改名为solr.war

    [root@bogon dist]# cp solr-4.10.3.war /usr/local/solr/tomcat/webapps/solr.war

    第四步:解压war包。启动tomcat自动解压。关闭tomcat。删除solr.war.

    第五步:把/root/solr-4.10.3/example/lib/ext 目录下所有的jar包复制到solr工程中(Tomcat的webappsolrWEB-INFlib目录下)。

    [root@bogon ext]# cp * /usr/local/solr/tomcat/webapps/solr/WEB-INF/lib/

    第六步:拷贝log4j.properties文件

     TomcatwebappssolrWEB-INF目录中创建文件 classes文件夹,

    复制Solr目录下example esourceslog4j.propertiesTomcatwebappssolrWEB-INFclasses目录 (如果没有classes则创建

    第七步:创建solrhome及配置solrconfig.xml文件Solrhome是存放solr服务器所有配置文件的目录。

    可以拷贝solr-4.10.3文件夹中的example目录下的solr实例

    [root@bogon example]# pwd
    /root/solr-4.10.3/example
    [root@bogon example]# cp -r solr /usr/local/solr/solrhome
    [root@bogon example]# 

    第八步:告诉solr服务器solrhome的位置。

    需要修改solr工程的web.xml文件。

    第九步:启动tomcat

     

    1.3 配置业务字段

    1、在solr中默认是没有中文分析器,需要手工配置。配置一个FieldType,在FieldType中指定中文分析器。

    2Solr中的字段必须是先定义后使用。

    1.3.1. 中文分析器的配置

    第一步:使用IK-Analyzer。把分析器的文件夹上传到服务器。

    第二步:需要把分析器的jar包添加到solr工程中。

    IKAnalyzer2012FF_u1.jar拷贝到 Tomcatwebapps/solr/WEB-INF/lib 下。

    第三步:需要把IKAnalyzer需要的扩展词典及停用词词典、配置文件复制到solr工程的classpath

    /usr/local/solr/tomcat/webapps/solr/WEB-INF/classes

    [root@bogon IK Analyzer 2012FF_hf1]# cp IKAnalyzer.cfg.xml ext_stopword.dic mydict.dic /usr/local/solr/tomcat/webapps/solr/WEB-INF/classes
    [root@bogon IK Analyzer 2012FF_hf1]# 

    注意:扩展词典及停用词词典的字符集必须是utf-8。不能使用windows记事本编辑。

    第四步:配置fieldType。需要在solrhome/collection1/conf/schema.xml中配置。

    技巧:使用vivim跳转到文档开头gg。跳转到文档末尾:G

    添加FieldType

    <fieldType name="text_ik" class="solr.TextField">
      <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>
    </fieldType>

    name="text_ik":一个标识可以随便写

    class="solr.TextField":分词分析器

    1.3.2. 业务字段配置

    Solr中的字段必须是先定义后使用。该配置要与我们的实际业务关联。

    业务字段判断标准:

    1、在搜索时是否需要在此字段上进行搜索。例如:商品名称、商品的卖点、商品的描述

    2、后续的业务是否需要用到此字段。例如:商品id

    需要用到的字段:

    1、商品id

    2、商品title

    3、卖点

    4、价格

    5、商品图片

    6、商品分类名称

    7、商品描述

    Solr中的业务字段:

    1、id——》商品id

    其他的对应字段创建solr的字段。

    在solrhome/collection1/conf/schema.xml 中添加 Solr中的业务字段:

    <field name="item_title" type="text_ik" indexed="true" stored="true"/>
    <field name="item_sell_point" type="text_ik" indexed="true" stored="true"/>
    <field name="item_price"  type="long" indexed="true" stored="true"/>
    <field name="item_image" type="string" indexed="false" stored="true" />
    <field name="item_category_name" type="string" indexed="true" stored="true" />
    <field name="item_desc" type="text_ik" indexed="true" stored="false" />
    
    <field name="item_keywords" type="text_ik" indexed="true" stored="false" multiValued="true"/>
    <copyField source="item_title" dest="item_keywords"/>
    <copyField source="item_sell_point" dest="item_keywords"/>
    <copyField source="item_category_name" dest="item_keywords"/>
    <copyField source="item_desc" dest="item_keywords"/>

      Field:域的定义 

    • Name:域的名称
    • Type:域的类型
    • Indexed:是否索引
    • Stored:是否存储
    • multiValued:是否多值,如果是多值在一个域中可以保持多个值。
    • dynamicField动态域 

      dynamicField:动态域 

    • Name:域的名称,是一个表达式。如果域的名称和表达式相匹配,此域名就可以使用。
    • Type:域的类型
    • Indexed:是否索引
    • Stored:是否存储
    • multiValued:是否多值,如果是多值在一个域中可以保持多个值。 

      uniqueKey 

    • 每个文档必须有一个uniqueKey,而且不能重复。相当于表中的主键。 

      copyField 

    • 复制域。
    • Source:源域
    • Dest:目标域。
    • 创建文档时,solr会自动把源域的内容复制到目标域。使用复制域可以提供查询的性能。 

      fieldType 

    • 域的类型。
    • Name:域类型名。
    • Class:对应的实现类。solr.TextField类似于Lucene中的TextField。可以配置用户自定义的分析器。

    重新启动tomcat

    1.4 维护索引库

    添加:添加一个json格式的文件就可以。

    修改:在solr中没有update,只需要添加一个新的文档,要求文档id和被修改文档的id一致。原理是先删除后添加。

    删除:使用xml格式。

     

    删除两种方法:

    1、根据id删除:

    <delete>

    <id>test001</id>

    </delete>

    <commit/>

    2、根据查询删除:

    <delete>

    <query>*:*</query>

    </delete>

    <commit/>

  • 相关阅读:
    Modelsim中观测代码覆盖率
    Allegro中Thermal relief Pad 和Anti Pad
    时序逻辑中阻塞赋值引起的仿真问题
    如何提高FPGA工作频率(转载)
    `include在Verilog中的应用
    forever
    wxpython 应用 使用 google gauth 认证
    sql to sqlalchemy 转换
    django 简易博客开发 5 markdown支持、代码高亮、gravatar头像服务
    simpletodo: 一个简易的 todo 程序 django版
  • 原文地址:https://www.cnblogs.com/laoyeye/p/6760846.html
Copyright © 2011-2022 走看看