1

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でjettyを使用しています。

4

2 に答える 2

1

textタイプの名前を好きに変更stringする

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

エラー メッセージは修正されますが、既存の solr の例を再利用schema.xmlし、必要に応じてフィールドを編集することを強くお勧めします。

アナライザーとフィルターを使用する複雑なタイプのフィールドを含めない場合、Solr 検索の恩恵を受けることはできません。

于 2013-10-23T14:45:20.737 に答える
0

次の行の「列」はクエリの列名と同じである必要があり、「名前」は使用したいものです。名前は schema.xml と一致する必要があります

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

You need to make this change in your schema.xml. Name of the field in schema.xml should be same as field name in 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>

and i dont see any version field in your SQL query, so i dont know what you are trying to use here.

Hope this helps.

于 2013-10-23T21:07:33.320 に答える