solr7在tomcat上的部署

1、前言

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

2、solr7.1.0的示例启动

由于solr本身集成了jetty服务器,所以可以直接启动。在solr的bin文件加下执行:

solr start

solr7在tomcat上的部署_第1张图片

在文件中也要相关提示:
solr7在tomcat上的部署_第2张图片
solr7在tomcat上的部署_第3张图片

3、启动效果

默认端口:8983
访问地址:http://localhost:8983/solr
solr7在tomcat上的部署_第4张图片

4、solr7在tomcat上的部署

solr6.x以上都需要JDK1.8以上版本。这里使用JDK1.8+tomcat8+solr7.x部署。
#####①准备环境:安装JDK1.8,tomcat8
#####②将solr-7.1.0/server/solr-webapp/下的webapp复制到apache-tomcat-8.5.23/webapps/下并且重命名(可以随意命名),这里命名为solr。
solr7在tomcat上的部署_第5张图片
#####③复制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/下。
solr7在tomcat上的部署_第6张图片
#####⑤复制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。
solr7在tomcat上的部署_第7张图片
#####⑦配置solrhome路径:修改apache-tomcat-8.5.23/webapps/solr/WEB-INF/下的web.xml文件。

     
    
    
       solr/home
       D:/20161010/test-demo/solr-test-7.1.0/solr-home
       java.lang.String
    

     

#####⑧取消权限控制,注释web.xml中的最后几行代码。否则项目会包403.

 
 

#####⑨初始化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
solr7在tomcat上的部署_第8张图片
选择自定义的core1,可以看到core1的相关信息。(部署over)

5、tomcat部署solr注意事项

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

  • core建立的时候,只要复制conf即可启动访问,data和core.properties可以通过窗口创建。

6、自定义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(可以不改名)。修改内容的结果为:


  
  
    
    
    
  

数据配置可以参考官方文档:https://wiki.apache.org/solr/DIHQuickStart
#####③修改solrconfig文件,添加导入信息。该信息必须放在requestHandler标签的同级位置。

	
		
		  data-config.xml
		
	

#####④自定义solr的字段,在managed-schema文件中添加filed字段。(位置放在 text 字段后面即可)

    
    
    
     

#####⑤添加IK分词器,引入IK分词器的依赖到apache-tomcat-8.5.23/webapps/solr/WEB-INF/lib/下,配置IK分词器(注意:放在fieldType同级附近)。


    

#####⑥启动solr,数据导入。
solr7在tomcat上的部署_第9张图片
#####⑦查询结果
solr7在tomcat上的部署_第10张图片

7、数据导入注意事项

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

  • 在使用q查询的时候,如果想直接输入查询,需要在sorconfig中设置默认查询。

8、参考资料

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

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

你可能感兴趣的:(框架篇)