Solr QueryElevationComponent中使用了未知的字段类型字符串
我使用DataImporter来索引MySQL记录,但每当我在浏览器上运行时,它都会给我这个错误Solr QueryElevationComponent中使用了未知的字段类型字符串,solr,indexing,jetty,Solr,Indexing,Jetty,我使用DataImporter来索引MySQL记录,但每当我在浏览器上运行时,它都会给我这个错误 HTTP ERROR 500 Problem accessing /solr/. Reason: {msg=SolrCore 'collection1' is not available due to init failure: Unknown FieldType: 'string' used in QueryElevationComponent,trace=org.apache.sol
HTTP ERROR 500
Problem accessing /solr/. Reason:
{msg=SolrCore 'collection1' is not available due to init failure: Unknown FieldType: 'string' used in QueryElevationComponent,trace=org.apache.solr.common.SolrException: SolrCore 'collection1' is not available due to init failure: Unknown FieldType: 'string' used in QueryElevationComponent
at org.apache.solr.core.CoreContainer.getCore(CoreContainer.java:785)
at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:295)
at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:195)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1419)
at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)
at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557)
at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)
at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075)
at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384)
at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)
at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)
at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255)
at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
at org.eclipse.jetty.server.Server.handle(Server.java:368)
at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:489)
at org.eclipse.jetty.server.BlockingHttpConnection.handleRequest(BlockingHttpConnection.java:53)
at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942)
at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004)
at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:640)
at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235)
at org.eclipse.jetty.server.BlockingHttpConnection.handle(BlockingHttpConnection.java:72)
at org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264)
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
at java.lang.Thread.run(Thread.java:724)
Caused by: org.apache.solr.common.SolrException: Unknown FieldType: 'string' used in QueryElevationComponent
at org.apache.solr.core.SolrCore.<init>(SolrCore.java:834)
at org.apache.solr.core.SolrCore.<init>(SolrCore.java:625)
at org.apache.solr.core.CoreContainer.createFromLocal(CoreContainer.java:524)
at org.apache.solr.core.CoreContainer.create(CoreContainer.java:559)
at org.apache.solr.core.CoreContainer$1.call(CoreContainer.java:249)
at org.apache.solr.core.CoreContainer$1.call(CoreContainer.java:241)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
at java.util.concurrent.FutureTask.run(FutureTask.java:166)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
at java.util.concurrent.FutureTask.run(FutureTask.java:166)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
... 1 more
Caused by: org.apache.solr.common.SolrException: Unknown FieldType: 'string' used in QueryElevationComponent
at org.apache.solr.handler.component.QueryElevationComponent.inform(QueryElevationComponent.java:169)
at org.apache.solr.core.SolrResourceLoader.inform(SolrResourceLoader.java:601)
at org.apache.solr.core.SolrCore.<init>(SolrCore.java:829)
... 13 more
,code=500}
HTTP错误500
访问/solr/时出现问题。原因:
{msg=SolrCore'collection1'因初始化失败而不可用:未知字段类型:QueryEvationComponent中使用的“字符串”,trace=org.apache.solr.common.SolrException:SolrCore'collection1'因初始化失败而不可用:QueryEvationComponent中使用的未知字段类型:“字符串”
位于org.apache.solr.core.CoreContainer.getCore(CoreContainer.java:785)
位于org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:295)
位于org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:195)
位于org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1419)
位于org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455)
位于org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)
位于org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557)
位于org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)
位于org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075)
位于org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384)
位于org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)
位于org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009)
位于org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)
位于org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255)
位于org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154)
位于org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)
位于org.eclipse.jetty.server.server.handle(server.java:368)
位于org.eclipse.jetty.server.AbstractHttpConnection.HandlerRequest(AbstractHttpConnection.java:489)
位于org.eclipse.jetty.server.blockingttpconnection.handleRequest(blockingttpconnection.java:53)
位于org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942)
位于org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004)
http.HttpParser.parseNext(HttpParser.java:640)
http.HttpParser.parseAvailable(HttpParser.java:235)
位于org.eclipse.jetty.server.blockingttpconnection.handle(blockingttpconnection.java:72)
位于org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264)
位于org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)
位于org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)
运行(Thread.java:724)
原因:org.apache.solr.common.SolrException:未知字段类型:QueryEvationComponent中使用了“字符串”
位于org.apache.solr.core.SolrCore(SolrCore.java:834)
位于org.apache.solr.core.SolrCore(SolrCore.java:625)
在org.apache.solr.core.CoreContainer.createFromLocal(CoreContainer.java:524)
位于org.apache.solr.core.CoreContainer.create(CoreContainer.java:559)
位于org.apache.solr.core.CoreContainer$1.call(CoreContainer.java:249)
位于org.apache.solr.core.CoreContainer$1.call(CoreContainer.java:241)
位于java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
在java.util.concurrent.FutureTask.run(FutureTask.java:166)中
位于java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
位于java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
在java.util.concurrent.FutureTask.run(FutureTask.java:166)中
位于java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
位于java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
…还有一个
原因:org.apache.solr.common.SolrException:未知字段类型:QueryEvationComponent中使用了“字符串”
位于org.apache.solr.handler.component.QueryLevationComponent.info(QueryLevationComponent.java:169)
位于org.apache.solr.core.SolrResourceLoader.inform(SolrResourceLoader.java:601)
位于org.apache.solr.core.SolrCore(SolrCore.java:829)
…还有13个
,代码=500}
这是我的Schema.xml文件。这很简单,因为我只是初学者
<schema name="example" version="1.5">
<types>
<fieldtype name="int" class="solr.TrieIntField" precisionStep="0" positionIncrementGap="0" />
<fieldtype name="text" class="solr.TextField" sortMissingLast="true" omitNorms="true" />
<fieldType name="long" class="solr.TrieLongField" precisionStep="0" positionIncrementGap="0"/>
</types>
<fields>
<field name="user_id" type="text" indexed="true" stored="true" required="true" />
<field name="user_name" type="text" indexed="true" stored="false" />
<field name="_version_" type="long" indexed="true" stored="true" multiValued="false"/>
</fields>
<uniqueKey>user_id</uniqueKey>
</schema>
用户id
这是我的db-data-config.xml
<?xml version="1.0" encoding="UTF-8"?>
<dataConfig>
<dataSource type="JdbcDataSource"
driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/solr_user"
user="root"
password="waseem"
batchSize="-1" />
<document name="user">
<entity name="user" query="SELECT user_id, user_name FROM users">
<field column="user_id" name="id" />
<field column="user_name" name="name" />
</entity>
</document>
</dataConfig>
谁能告诉我上面的代码有什么问题,为什么我会出现这个错误。任何帮助都将不胜感激。我正在Ubuntu上使用jetty。将您的
文本
类型重命名为字符串
类似
<fieldType name="string" class="solr.StrField" sortMissingLast="true" />
这将修复错误消息,但我强烈建议重用现有的solr示例schema.xml
,并根据需要编辑字段
如果不包含使用分析器和过滤器的复杂类型的字段,您将无法从Solr搜索中获益 将
文本
类型重命名为字符串
类似
<fieldType name="string" class="solr.StrField" sortMissingLast="true" />
这将修复错误消息,但我强烈建议重用现有的solr示例schema.xml
,并根据需要编辑字段
如果不包含使用分析器和过滤器的复杂类型的字段,您将无法从Solr搜索中获益 在下一行中,“column”应该和查询中的列名相同,“name”是您想要使用的。和名称应与schema.xml匹配
<field column="user_id" name="id" />
您需要在schema.xml中进行此更改。schema.xml中的字段名应与字段名相同