Solr“未定义的字段文本”

时间:2012-07-03 10:59:40

标签: java tomcat solr

我最近将我的solr实例从1,4升级到3.6。但是,每当我更新索引时,我现在似乎在日志中收到“未定义的字段文本”严重消息。

我的架构中有文本字段(从版本1.4起有效),但以前从未将其声明为字段类型。这有没改变在3.6?

我的架构在这里>> http://pastebin.com/KrCVab0U

SEVERE: org.apache.solr.common.SolrException: undefined field text
        at org.apache.solr.schema.IndexSchema.getDynamicFieldType(IndexSchema.java:1330)
        at org.apache.solr.schema.IndexSchema$SolrQueryAnalyzer.getAnalyzer(IndexSchema.java:408)
        at org.apache.solr.schema.IndexSchema$SolrIndexAnalyzer.reusableTokenStream(IndexSchema.java:383)
        at org.apache.lucene.queryParser.QueryParser.getFieldQuery(QueryParser.java:574)
        at org.apache.solr.search.SolrQueryParser.getFieldQuery(SolrQueryParser.java:206)
        at org.apache.lucene.queryParser.QueryParser.Term(QueryParser.java:1429)
        at org.apache.lucene.queryParser.QueryParser.Clause(QueryParser.java:1317)
        at org.apache.lucene.queryParser.QueryParser.Query(QueryParser.java:1245)
        at org.apache.lucene.queryParser.QueryParser.TopLevelQuery(QueryParser.java:1234)
        at org.apache.lucene.queryParser.QueryParser.parse(QueryParser.java:206)
        at org.apache.solr.search.LuceneQParser.parse(LuceneQParserPlugin.java:79)
        at org.apache.solr.search.QParser.getQuery(QParser.java:143)
        at org.apache.solr.handler.component.QueryComponent.prepare(QueryComponent.java:105)
        at org.apache.solr.handler.component.SearchHandler.handleRequestBody(SearchHandler.java:165)
        at org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:129)
        at org.apache.solr.core.SolrCore.execute(SolrCore.java:1376)
        at org.apache.solr.handler.PingRequestHandler.handleRequestBody(PingRequestHandler.java:67)
        at org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:129)
        at org.apache.solr.core.SolrCore.execute(SolrCore.java:1376)
        at org.apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:365)
        at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:260)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
        at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:602)
        at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
        at java.lang.Thread.run(Thread.java:679)

5 个答案:

答案 0 :(得分:22)

不是关于字段类型“文本”。它是关于字段命名为“文本”。

您已将配置中的默认字段更改为“search_text”。请尝试将对“search_text”的所有引用重命名为“text”。如果这样可以解决问题,那么您知道配置中的某个位置是指“text”字段,可能是在Solr Query - HTTP error 404 undefined field text中建议的solrconfig.xml中

希望它有所帮助。

答案 1 :(得分:9)

我在我的solrconfig.xml文件中有这个。

<requestHandler name="/admin/ping" class="solr.PingRequestHandler">
 <lst name="invariants">
  <str name="q">solrpingquery</str>
 </lst>
 <lst name="defaults">      
  <str name="echoParams">all</str>
  </lst>
</requestHandler>

如果你还没有在schema.xml中添加它,那么添加它

<field name="text" type="text_general" indexed="true" stored="false" multiValued="true"/>

这将解决您的问题。

由于

答案 2 :(得分:3)

今天也发生了我的事。如果您在发生错误时进行查询,则需要在查询中双引用数据,如下所示:

filepath:“要查询的数据”

答案 3 :(得分:2)

当我清理查询的fq部分时,我遇到了同样的错误。消毒后,solr收到了

...&fq=type\:Product&...

虽然我的字段名为type,但错误是“未定义字段文本”。

当我删除清理时,查询就可以了:

...&fq=type:Product&...

混淆错误消息的原因在solrconfig.xml中:

<requestHandler name="/select" class="solr.SearchHandler">
  <lst name="defaults">
    <str name="echoParams">explicit</str>
    <int name="rows">10</int>
    <str name="df">text</str>
  </lst>
</requestHandler>

答案 4 :(得分:2)

在solr管理界面中,您可以看到当前正在运行的方案,然后您可以确定您是否在正确的路径上。低于图片说明

4.10.2及更高版本(假设)

solr.4.10.2

低于4.10.2的版本。你应该使用左侧的 Scheme 菜单。

solr.4.10.2