• solr与tomcat集成


    1.准备tomcat8、solr6、solr-home

    注意,如果用tomcat7或者之前的版本,因为jar包版本缘故,会出现java.lang.NoSuchMethodError 错误

    解压tomcat8,命名为solr-tomcat-8

    解压solr6

    在同级目录下,新建solr-home目录

    2.拷贝solr项目和jar包

    进入目录 solr-6.3.0serversolr-webapp,将webapp整个目录复制到刚刚tomcat的webapps目录下面,并重命名为solr

    将solr-6.3.0serverlibext 下的所有jar包,拷到tomcat/lib 目录下

    将./solr-6.3.0/dist/ 目录下的solr-dataimporthandler-6.3.0.jar 和solr-dataimporthandler-extras-6.3.0.jar也拷贝到tomcat的lib 路径下

     3.拷贝log4j并修改日志目录

     将solr-6.3.0server esourceslog4j.properties 文件拷贝到tomcat的webappssolrWEB-INFclassess

     编辑log4j文件,替换${solr.log}为tomcat路径

    4.配置solr-home

    将 solr-6.3.0serversolr 所有文件拷贝到 solr-home下

    然后编辑 tomcat的 webappssolrWEB-INFweb.xml,去掉env-entry标签的注释,并将env-entry-value的值设置为solr-home的路径

     

    5.注释solr权限

    修改tomcat的webappssolrWEB-INFweb.xml,注释<security-constraint>标签及内容

    注意:如果不注释,访问solr主页,会报403错误

    以上配置完成后,启动tomcat,访问主页:http://localhost:8080/solr/index.html

    6.添加core

    点击core admin,点击 Add Core,添加一个新的core

    查看solr-home,多了一个文件夹,这里面就是新加core的数据和配置

     可能出现的错误及解决方案

    1-5 摘自:https://segmentfault.com/a/1190000010387238,6为本人亲自遇到

    1.启动tomcat时如果报下面的错误:

    严重: Exception starting filter SolrRequestFilter
    java.lang.NoClassDefFoundError: com/codahale/metrics/MetricSetat java.lang.Class.getDeclaredConstructors0(Native Method)
    at java.lang.Class.privateGetDeclaredConstructors(Class.java:2671)
    at java.lang.Class.getConstructor0(Class.java:3075)at java.lang.Class.newInstance(Class.java:412)
    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:119)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:105)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4700)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5340)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:145)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:753)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:729)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:717)
    at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:1092)
    at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java:1834)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)Caused by: java.lang.ClassNotFoundException:com.codahale.metrics.MetricSet
    at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1333)
    at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1167)
    ... 20 more

    请把solr-6.4.1/server/lib下的metrics-core-3.1.2.jar,metrics-ganglia-3.1.2.jar,metrics-graphite-3.1.2.jar,metrics-jetty9-3.1.2.jar,metrics-jvm-3.1.2.jar这几个jar包放到tomcat下的solr项目的WEB-INF/lib目录下。

    2.访问http://localhost:8080/solr/index.html时如果报下面的错误:

    HTTP Status 403 - Access to the requested resource has been denied

    把tomcat下的solr项目的web.xml文件中

    <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>

    这段注释掉。这段配置限制了对solr资源的访问,注释掉就可以访问了。

    3.java.lang.NoSuchMethodError:

    解决:solr5.5以上版本在tomcat8下运行
    由于solr5.5.0和solr5.5.1 版本部署在tomcat7下的时候,会报Java.lang.NoSuchMethodError: javax.servlet.ServletInputStream.isFinished()Z的错误,这个是serverlet3.1才有的方法。

    4.javax.servlet.ServletInputStream.isFinished

    解决:solr5版本以上的部署最好使用JDK1.8
    solr5版本以上的部署最好使用JDK1.8,虽然官网没有明确表示solr5必须是要使用JDK1.8,但是其中一部分功能锁需求的JDK版本在JDK1.7以下是没有的
    比如:Java.lang.NoSuchMethodError: javax.servlet.ServletInputStream.isFinished()Z
    我是在全量索引的时候发生的此异常提示:找不到ServletInputStream类下面的isFinished()方法,那么现在我们找到该类ServletInputStream
    如果在这个类下面没有isFinished()方法,那就是JAR包问题,这个类所在的jar包是servlet-api.jar

    5.待解决:

    web.xml 文件中 的 <welcome-file-list> 标签失效的原因 。

    正常部署后,直接访问 localhost:8080/solr 应该就可以使用,但是,会出现不能加载 UI 的说明。

    只有访问 localhost:8080/solr/index.html 才可以正常加载。

    分析web.xml 文件,发现一段 servlet 配置

     <servlet>
        <servlet-name>LoadAdminUI</servlet-name>
        <servlet-class>org.apache.solr.servlet.LoadAdminUiServlet</servlet-class>
      </servlet>    
      <servlet-mapping>
        <servlet-name>LoadAdminUI</servlet-name>
        <url-pattern>/index.html</url-pattern>
      </servlet-mapping>

     6.Error processing the request. CoreContainer is either not initialized or shutting down

    如果配置了zookeeper,则检查zk是否正常启动或配置错误

    否则,检查solr-tomcat-8webappssolrWEB-INFweb.xml中的solr-home配置是否正确

  • 相关阅读:
    flutter item列表左右滑动带出按钮选项
    flutter之Dismissible组件
    mac下最好用的抓包工具--charles简单操作教程
    flutter 开起charles抓包代理
    nodejs querystring模块
    node.js 中使用 Mongodb
    MongoDB 的高级查询 aggregate 聚合管道
    Mongodb 关系型数据库表(集合)与表(集合)之 间的几种关系
    Mongodb 的使用以及 Mongodb 账户权 限配置
    MongoDb 大数据查询优化、 MongoDB 索引、复合索引、唯一索引、 explain 分 析查询速度
  • 原文地址:https://www.cnblogs.com/yangzhenlong/p/8268643.html
Copyright © 2020-2023  润新知