3

SolrNetが「追加」メソッドを実行するところまで来ましたが、「コミット」しようとするとエラーが発生します。以下は、私の schema.xml、モデル、それを呼び出すコード、および表示されるエラーです。さらに奇妙なのは、エラーにもかかわらず、Tomcat を再起動した後にモデルが Solr インデックスに追加されることです (そのため、エラーにもかかわらずモデルが追加されますが、すぐには追加されません)。

schema.xml (フィールドとフィールドタイプ):

<!-- Fields -->   
<field name="part_numbers" type="my_string_exact" indexed="true" stored="true" multiValued="true" />
<field name="page_url" type="my_string_exact" indexed="true" stored="true" />
<field name="product_name" type="my_string" indexed="true" stored="true" />
<!-- FieldTypes -->
<fieldType name="my_string_exact" class="solr.StrField" sortMissingLast="true" omitNorms="true"/>
<fieldType name="my_string" class="solr.TextField" sortMissingLast="true" omitNorms="true">
  <analyzer type="index">
    <tokenizer class="solr.KeywordTokenizerFactory" />
    <filter class="solr.LowerCaseFilterFactory" />
  </analyzer>
  <analyzer type="query">
    <tokenizer class="solr.KeywordTokenizerFactory" />
    <filter class="solr.LowerCaseFilterFactory" />
  </analyzer>
</fieldType>
<fieldType name="my_int" class="solr.IntField" omitNorms="true" />

モデル (Product.cs) *注 - PageId は、Solr の既定の "id" を使用します。これは、一意で必須の文字列です。

public class Product
{
    [SolrUniqueKey("id")]
    public string PageId { get; set; }

    [SolrField("part_numbers")]
    public ICollection<string> PartNumbers { get; set; }

    [SolrField("page_url")]
    public string PageUrl { get; set; }

    [SolrField("product_name")]
    public string Name { get; set; }
}

コードの初期化、Add および Commit の呼び出し *注 - これは単体テストであるため、init は 1 回だけ呼び出されます。

Startup.Init<Product>("http://localhost:8080/solr");
Product testProd = new Product() { 
            EPiPageId = "44", 
            Name = "TestProd3", 
            PageUrl = "/TestProd3", 
            PartNumbers = new List<string>() { "000022222", "000000333333" } 
        };
var solr = ServiceLocator.Current.GetInstance<ISolrOperations<Product>>();
solr.Add(testProd);
solr.Commit(); // Bad Request Error occurs here.

エラー メッセージ:

SolrNet.Exceptions.SolrConnectionException was unhandled by user code
  HResult=-2146232832
  Message=The remote server returned an error: (400) Bad Request.
  Source=SolrNet
  StackTrace:
       at SolrNet.Impl.SolrConnection.Post(String relativeUrl, String s) in c:\prg\SolrNet\svn\SolrNet\Impl\SolrConnection.cs:line 104
       at SolrNet.Commands.CommitCommand.Execute(ISolrConnection connection) in c:\prg\SolrNet\svn\SolrNet\Commands\CommitCommand.cs:line 71
       at SolrNet.Impl.SolrBasicServer`1.Send(ISolrCommand cmd) in c:\prg\SolrNet\svn\SolrNet\Impl\SolrBasicServer.cs:line 87
       at SolrNet.Impl.SolrBasicServer`1.SendAndParseHeader(ISolrCommand cmd) in c:\prg\SolrNet\svn\SolrNet\Impl\SolrBasicServer.cs:line 91
       at SolrNet.Impl.SolrBasicServer`1.Commit(CommitOptions options) in c:\prg\SolrNet\svn\SolrNet\Impl\SolrBasicServer.cs:line 54
       at SolrNet.Impl.SolrServer`1.Commit() in c:\prg\SolrNet\svn\SolrNet\Impl\SolrServer.cs:line  24
  InnerException: System.Net.WebException
       HResult=-2146233079
       Message=The remote server returned an error: (400) Bad Request.
       Source=System
       StackTrace:
            at System.Net.HttpWebRequest.GetResponse()
            at HttpWebAdapters.Adapters.HttpWebRequestAdapter.GetResponse() in c:\prg\SolrNet\svn\HttpWebAdapters\Impl\HttpWebRequestAdapter.cs:line 36
            at SolrNet.Impl.SolrConnection.GetResponse(IHttpWebRequest request) in c:\prg\SolrNet\svn\SolrNet\Impl\SolrConnection.cs:line 160
            at SolrNet.Impl.SolrConnection.Post(String relativeUrl, String s) in c:\prg\SolrNet\svn\SolrNet\Impl\SolrConnection.cs:line 101
       InnerException: 

EDIT答えてくれたPaigeに感謝します。問題は、古いバージョンのSolrNetのバグである「waitFlush」エラーでした。私が使用していた SolrNet のバージョンは、0.3.1 の VS NuGet のものでした (最新の安定ビルドであると想定していました)。彼らのGoogleコードサイトには最新のビルドはありませんが、ビルドサーバー(ここではhttp://teamcity.codebetter.com/project.html?projectId=project36&guest=1「artifacts」の下)には修正された最新のものがありますこのバグ。問題は解決しました。

4

1 に答える 1