solr7在tomcat上的部署

一、前言html

solr是基于lucence的企业级搜索服务器。以前使用的都是4.x版本,可是在5.x以后solr的目录结构已经发生了变化,不在提供war包。因此在tomcat部署的时候,稍有区别。尤为如今的最新版本已是7.x了,部署的时候有一些变化。java

二、solr7.1.0的示例启动mysql

因为solr自己集成了jetty服务器,因此能够直接启动。在solr的bin文件加下执行:web

solr start
1sql


在文件中也要相关提示:数据库

三、启动效果apache

默认端口:8983
访问地址:http://localhost:8983/solrtomcat


四、solr7在tomcat上的部署服务器

solr6.x以上都须要JDK1.8以上版本,solr7要用tomcat8才能启动。这里使用JDK1.8+tomcat8+solr7.x部署。
#####①准备环境:安装JDK1.8,tomcat8
#####②将solr-7.1.0/server/solr-webapp/下的webapp复制到apache-tomcat-8.5.23/webapps/下而且重命名(能够随意命名),这里命名为solr。app

#####③复制solr-7.1.0/server/lib/ext下的全部jar,到apache-tomcat-8.5.23/webapps/solr/WEB-INF/lib/下。(没错,这个就是那个重命名solr下的WEB-INF/lib)
#####④复制solr-7.1.0/server/lib/下metrics相关的jar,到apache-tomcat-8.5.23/webapps/solr/WEB-INF/lib/下。

#####⑤复制solr-7.1.0/server/resources下的log4j.properties文件,到apache-tomcat-8.5.23/webapps/solr/WEB-INF/下的classes文件夹中。(classes文件夹若是没有须要本身建立,这是日志文件)
#####⑥建立solrhome:复制solr-7.1.0/server/下的solr文件夹,到任意目录处(能够从新命名,这里重命名为solr-home,笔者solrhome路径为:D:\20161010\test-demo\solr-test-7.1.0\solr-home),自定义solrhome。

#####⑦配置solrhome路径:修改apache-tomcat-8.5.23/webapps/solr/WEB-INF/下的web.xml文件。

     
    <!-- 方法1:默认代码为注释状态。放开以后,替换<env-entry-value></env-entry-value>中间的值为本身的solrhome -->
    <env-entry>
       <env-entry-name>solr/home</env-entry-name>
       <env-entry-value>D:/20161010/test-demo/solr-test-7.1.0/solr-home</env-entry-value>
       <env-entry-type>java.lang.String</env-entry-type>
    </env-entry>

    <!--
     方法2:
     修改tomcat的配置文件, 在apache-tomcat-8.5.23/bin/catalina.bat文件中的第二行加配置参数。也就是@echo off下面一行。
     
    set "JAVA_OPTS=-Dsolr.solr.home=D:/20161010/test-demo/solr-test-7.1.0/solr-home
    --> 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#####⑧取消权限控制,注释web.xml中的最后几行代码。不然项目会包403.

 <!-- Get rid of error message -->
 <!--
  <security-constraint>
    <web-resource-collection>
      <web-resource-name>Disable TRACE</web-resource-name>
      <url-pattern>/</url-pattern>
      <http-method>TRACE</http-method>
    </web-resource-collection>
    <auth-constraint/>
  </security-constraint>
  <security-constraint>
    <web-resource-collection>
      <web-resource-name>Enable everything but TRACE</web-resource-name>
      <url-pattern>/</url-pattern>
      <http-method-omission>TRACE</http-method-omission>
    </web-resource-collection>
  </security-constraint>
  
  -->
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#####⑨初始化solr-home的数据,在solr-home文件下建一个core1(名字随意取),复制solr-home/configsets/_default/下的conf文件夹,到新建的core1下,在core1下建立文件夹data(空文件加便可)和core.properties(内容只配置name=core1便可,这里的name的值也就是再页面要显示的solrhome名称)

#####⑩访问http://localhost:8080/solr/index.html

选择自定义的core1,能够看到core1的相关信息。(部署over)

五、tomcat部署solr注意事项

tomcat7和solr7不兼容,一样的方法使用tomcat7,访问有异常。

core创建的时候,只要复制conf便可启动访问,data和core.properties能够经过窗口建立。

六、自定义core,导入数据库索引

这里自定义的core为core2,以此为例。

#####①引入jar依赖:在apache-tomcat-8.5.23/webapps/solr/WEB-INF/lib/引入mysql的驱动(mysql-connector-java-5.1.32.jar),复制solr-7.1.0/dist/下的solr-dataimporthandler-7.1.0.jar和solr-dataimporthandler-extras-7.1.0.jar,到apache-tomcat-8.5.23/webapps/solr/WEB-INF/lib/的下面。
#####②复制solr-7.1.0/example/example-DIH/solr/db/conf/下的db-data-config.xml到solr-home/core2/conf/下,此处更名为data-config.xml(能够不更名)。修改内容的结果为:

<dataConfig>
  <dataSource type="JdbcDataSource" 
              driver="com.mysql.jdbc.Driver"
              url="jdbc:mysql://127.0.0.1:3306/数据库名" 
              user="root" 
              password="root"/>
  <document>
    <!--指定须要导入的数据库表名,以及数据 -->
    <entity name="lsh_information" 
            query="select id,title,content,create_user_name,create_time from lsh_information">
    </entity>
  </document>
</dataConfig>
1
2
3
4
5
6
7
8
9
10
11
12
13
数据配置能够参考官方文档:https://wiki.apache.org/solr/DIHQuickStart
#####③修改solrconfig文件,添加导入信息。该信息必须放在requestHandler标签的同级位置。

    <requestHandler name="/dataimport" class="org.apache.solr.handler.dataimport.DataImportHandler">
        <lst name="defaults">
          <str name="config">data-config.xml</str>
        </lst>
    </requestHandler>
1
2
3
4
5
#####④自定义solr的字段,在managed-schema文件中添加filed字段。(位置放在 text 字段后面便可)

    <field name="title" type="text_ik" indexed="true" stored="true" multiValued="false"/>
    <field name="content" type="string" indexed="false" stored="true" multiValued="false"/>
    <field name="create_user_name" type="string" indexed="true" stored="true" multiValued="false"/>
    <field name="create_time" type="pdate" indexed="true" stored="true" multiValued="false"/> 
1
2
3
4
#####⑤添加IK分词器,引入IK分词器的依赖到apache-tomcat-8.5.23/webapps/solr/WEB-INF/lib/下,配置IK分词器(注意:放在fieldType同级附近)。

<fieldType name="text_ik" class="solr.TextField">
    <analyzer class="org.wltea.analyzer.lucene.IKAnalyzer"/>
</fieldType>
1
2
3
#####⑥启动solr,数据导入。

#####⑦查询结果


七、数据导入注意事项

IK分词器最新版本是 IKAnalyzer2012FF_u1.jar,官方已经中止更新的。该最新版本不兼容solr7,使用的时候会没法分词。笔者这里导入的是网上大佬改进的版本。

在使用q查询的时候,若是想直接输入查询,须要在sorconfig中设置默认查询。

八、参考资料

博文资料: http://blog.csdn.net/tanzhen1991910/article/details/53488398(此博文有提供修改过的IK分词器)

官方资料:https://wiki.apache.org/solr  

相关文章
相关标签/搜索