我最近将我的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)
答案 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及更高版本(假设)
低于4.10.2的版本。你应该使用左侧的 Scheme 菜单。