1

SolR 3.6 のテスト環境があり、それを 4.0 に移行しようとしていますが、次のエラーが発生します。

主なソースコードは次のとおりです。

public class SolrConfigTest extends AbstractSolrTestCase {
    String container = "mycore";

    @Override
    public String getSolrHome() {
        return System.getProperty("user.dir") + "/resources/";
    }

    @Override
    public String getSchemaFile() {
        return getSolrHome() + container + "/conf/schema.xml";
    }

    @Override
    public String getSolrConfigFile() {
        return getSolrHome() + container + "/conf/solrconfig.xml";
    }

    @Before
    @Override
    public void setUp() throws Exception {
        super.setUp();
        CoreContainer.Initializer initializer = new CoreContainer.Initializer();
        coreContainer = initializer.initialize();
        server = new EmbeddedSolrServer(coreContainer, "mycore");
    }
}

solr フォルダー構造:

+solr
   +mycore
      +conf
      +data
      +lib

solr.xml 構成ファイル:

<?xml version="1.0" encoding="UTF-8" ?>
<solr persistent="false">
  <cores adminPath="/admin/cores" defaultCoreName="mycore" host="${host:}" hostPort="${jetty.port:}" hostContext="${hostContext:}" zkClientTimeout="${zkClientTimeout:15000}">
    <core name="mycore" instanceDir="mycore" />
  </cores>
</solr>

ただし、このコードを実行すると、次のエラーが発生します。

 [java] 16-dic-2012 0:43:15 SolrConfig <init>
 [java] 16-dic-2012 0:43:15 org.apache.solr.util.AbstractSolrTestCase setUp
 [java] INFO: ####SETUP_START <unknown>
 [java] 16-dic-2012 0:43:15 org.apache.solr.core.SolrResourceLoader <init>
 [java] INFO: new SolrResourceLoader for directory: '/home/user/workspace/tech/SolrTest/resources//collection1/'
 [java] 16-dic-2012 0:43:16 org.apache.solr.core.SolrConfig initLibs
 [java] INFO: Adding specified lib dirs to ClassLoader
 [java] 16-dic-2012 0:43:16 org.apache.solr.core.SolrConfig <init>
 [java] INFO: Using Lucene MatchVersion: LUCENE_40
 [java] 16-dic-2012 0:43:16 org.apache.solr.core.SolrConfig <init>
 [java] INFO: Loaded SolrConfig: /home/user/workspace/tech/SolrTest/resources/mycore/conf/solrconfig.xml
 [java] 16-dic-2012 0:43:16 org.apache.solr.schema.IndexSchema readSchema
 [java] INFO: Reading Solr Schema
 [java] 16-dic-2012 0:43:16 org.apache.solr.schema.IndexSchema readSchema
 [java] INFO: Schema name=mycore
 [java] 16-dic-2012 0:43:17 org.apache.solr.schema.IndexSchema readSchema
 [java] INFO: unique key field: ID
 [java] java.lang.RuntimeException: java.io.IOException: Can't find resource 'stopwords.txt' in classpath or

'/home/user/workspace/tech/SolrTest/resources//collection1/conf/', cwd=/home/user/workspace/tech/SolrTest [java] at org.apache.solr.schema.IndexSchema.(IndexSchema.ジャワ:116)

SolR は solr.xml を見つけることができない (しかし、solrconfig.xml を見つける) ようであり、それが collection1 にアクセスしようとする理由です (solr が solr.xml を見つけられない場合、core を collection1 に設定することを読みました)。 、しかし getSolrHome() は solr.xml が保存されているフォルダーを指しています。

私は何を間違っていますか?

敬具

4

2 に答える 2

2

間違った solr ホームを指定した可能性があります。

以下を試してください、

    @Override
    public String getSolrHome() {
        return System.getProperty("user.dir") + "/resources/solr";
    }
于 2013-03-03T09:07:42.280 に答える
1

実際には、Solrstopwords.txtのフォルダーにファイルが見つからないというエラーが表示されます。confディレクトリに stopwords.txt ファイルが存在することを確認できますか/home/user/workspace/tech/SolrTest/resources/mycore/conf/

スキーマ ファイル内の fieldType のアナライザー/フィルターが stopwords.txt ファイルを参照しているため、このエラーが報告されています。

于 2012-12-16T02:14:57.650 に答える