【问题标题】:Unknown Fieldtype String used in QueryElevationComponentQueryElevationComponent 中使用的未知字段类型字符串
【发布时间】:2013-10-23 13:34:49
【问题描述】:

我正在使用 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.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}

这是我的 Schema.xml 文件。这么简单,因为我只是 SOLR 的初学者。

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

这是我的 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 上使用码头。

【问题讨论】:

    标签: solr indexing jetty


    【解决方案1】:

    将您的 text 类型重命名为 string 类似

    <fieldType name="string" class="solr.StrField" sortMissingLast="true" />
    

    这将修复错误消息,但我强烈建议重用现有的 solr 示例 schema.xml 并根据您的需要编辑字段。

    如果您不包含使用分析器和过滤器的复杂类型的字段,您将无法从 Solr 搜索中受益。

    【讨论】:

    • 我已经按照你说的重命名了字段,现在我得到了未定义的字段文本异常。
    • 还需要将user_id的类型...改为字符串
    • 是的,我已将其更改为字符串。
    • 最直接的解决方案是重用示例中的模式(或至少使用定义的类型)并调整字段
    【解决方案2】:

    在下一行中,“column”应该与查询中的列名相同,“name”是您要使用的。并且名称应与 schema.xml 匹配

     <field column="user_id" name="id" />
    

    您需要在您的 schema.xml 中进行此更改。 schema.xml 中的字段名称应与 data-config.xml 中的字段名称相同。

       <fields>
            <field name="id" type="text" indexed="true" stored="true" required="true"  />
            <field name="name" type="text" indexed="true" stored="false" />
       </fields>
    

    而且我在您的 SQL 查询中没有看到任何 version 字段,所以我不知道您在此处尝试使用什么。

    希望这会有所帮助。

    【讨论】:

    • 感谢您的回复,当我不在架构中使用该版本时,我收到此错误无法使用 updateLog:version 字段必须存在于架构中。所以这就是我正在使用的,我是 Solr 的新手。
    • 谢谢它的工作。我在 db 中只有 3 条记录,但是获取它需要很长时间,你知道它出了什么问题吗?
    • 如果只有三条记录,不惜一切代价不超过一分钟。你能把你的 Schema.xml 和 solrConfig.xml 放在某个地方并给我链接,我可以看看它。您也可以尝试删除 batchSize 参数,因为当您要从数据库中获取大数据时它很有用,并且 batchSize 参数通过每次处理并提交小数据时获取小数据来避免 java 堆异常。
    • 这里是这些文件的链接gist.github.com/anonymous/7137753。我真的需要在每个架构中都有 version 列吗?
    • 不,您的架构中永远不必有版本。我看到您的 schema.xml 非常小,并且我有一个更大的 schema.xml,其中包含许多标记器和过滤器,它们确定了您的数据将如何被标记化以及您可以应用哪些过滤(如果您需要,您可能想阅读它更多信息)。但是您使用的是 solr 4.5,而我仍在使用 3.6,所以这可能会有所不同。好吧,我不知道 4.5,但我仍在分享我的 schema.xml @dropbox.com/sh/5imwxom2y9r84em/luln92Kl91/schema.xml,看看,你可能会找到一些东西。
    猜你喜欢
    • 1970-01-01
    • 2016-07-22
    • 2021-10-19
    • 1970-01-01
    • 2021-02-03
    • 1970-01-01
    • 2023-04-03
    • 1970-01-01
    • 2020-11-24
    相关资源
    最近更新 更多