3

以下をSolrサーバーに投稿しています:

<add>
    <doc>
        <field name="uniqueid">5453543</field>
        <field name="modifieddate">2008-12-03T15:49:00Z</field>
        <field name="title">My Record</field>
        <field name="description">Descirption 
        Details
</field>
        <field name="startdate">2009-01-21T15:26:05.680Z</field>
        <field name="enddate">2009-01-21T15:26:05.697Z</field>
        <field name="Telephone_number">11111 111 111(text phone)</field>
        <field name="Telephone_number">11111 111 111</field>
        <field name="Mobile_number">1111111111</field>
    </doc>
</add>

SolrNetを使用してドキュメントを送信しています。コードからの抜粋です (s は上記の xml です)。

public string Post(string relativeUrl, string s) 
{
    var u = new UriBuilder(serverURL);
    u.Path += relativeUrl;
    var request = httpWebRequestFactory.Create(u.Uri);
    request.Method = HttpWebRequestMethod.POST;
    request.KeepAlive = false;
    if (Timeout > 0)
        request.Timeout = Timeout;
    request.ContentType = "text/xml; charset=utf-8";
    request.ContentLength = s.Length;
    request.ProtocolVersion = HttpVersion.Version10;
    try 
    {
        using (var postParams = request.GetRequestStream()) 
        {
            postParams.Write(xmlEncoding.GetBytes(s), 0, s.Length);
            using (var response = request.GetResponse()) 
            {
                using (var rStream = response.GetResponseStream()) 
                {
                    string r = xmlEncoding.GetString(ReadFully(rStream));
                    //Console.WriteLine(r);
                    return r;
                }
            }
        }
    } 
    catch (WebException e) 
    {
        throw new SolrConnectionException(e);
    }
}

request.GetResponse に到達すると、次のエラーで失敗しました:

base {System.InvalidOperationException} = {"リモート サーバーがエラーを返しました: (500) 内部サーバー エラー"}

Apache のログでサーバーを調べると、次の理由が表示されます。

最後に入力ブロックが予期せず終了しました

完全なスタック トレースは次のとおりです。

2009 年 9 月 17 日 10:13:53 AM org.apache.solr.common.SolrException ログ SEVERE: com.ctc.wstx.exc.WstxEOFException: [row,col {unknown-source} の終了タグの入力ブロックの予期しない終了]: [26,1266] com.ctc.wstx.sr.StreamScanner.throwUnexpectedEOB(StreamScanner.java:700) で com.ctc.wstx.sr.StreamScanner.loadMoreFromCurrent(StreamScanner.java:1054) で com.ctc. com.ctc.wstx.sr.BasicStreamReader.readEndElem(BasicStreamReader.java:3211) の wstx.sr.StreamScanner.getNextCharFromCurrent(StreamScanner.java:811) com.ctc.wstx.sr.BasicStreamReader.nextFromTree(BasicStreamReader.java: 2832) で com.ctc.wstx.sr.BasicStreamReader.next(BasicStreamReader.java:1019) で org.apache.solr.handler.XmlUpdateRequestHandler.processUpdate(XmlUpdateRequestHandler.java:148) で org.apache.solr.handler.XmlUpdateRequestHandler.handleRequestBody(XmlUpdateRequestHandler.java:123) org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:131) org.apache.solr.core.SolrCore.execute(SolrCore.java:1204) org .apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:303) org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:232) org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain) .java:235) org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) org.apache.catalina. org.apache.catalina.core の core.StandardContextValve.invoke(StandardContextValve.java:191)。StandardHostValve.invoke(StandardHostValve.java:128) org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) org .apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) at org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) at org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process (Http11AprProtocol.java:574) org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1527) で java.lang.Thread.run(Thread.java:619)109) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) で org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) で org.apache.coyote.http11.Http11AprProtocol $Http11ConnectionHandler.process(Http11AprProtocol.java:574) at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1527) at java.lang.Thread.run(Thread.java:619)109) org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) で org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) で org.apache.coyote.http11.Http11AprProtocol $Http11ConnectionHandler.process(Http11AprProtocol.java:574) at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1527) at java.lang.Thread.run(Thread.java:619)

Solr サーバーは次のシステムで実行されていることに注意してください。

Microsoft Windows Server 2003 R2 Apache Tomcat 6

最後に私の質問は次のとおりです。

私が送信している Xml は私には問題ないように見えます.Solr がこの例外をスローしている理由について誰か考えがありますか?

ありがとう

デイブ

編集回答は次のとおりです。

public string Post(string relativeUrl, string s) 
{
    var u = new UriBuilder(serverURL);
    u.Path += relativeUrl;
    var request = httpWebRequestFactory.Create(u.Uri);
    request.Method = HttpWebRequestMethod.POST;
    request.KeepAlive = false;
    if (Timeout > 0)
        request.Timeout = Timeout;
    request.ContentType = "text/xml; charset=utf-8";
    request.ProtocolVersion = HttpVersion.Version10;
    try 
    {
        // Set the Content length after the size of the byte array has been calculated.
        byte[] data = xmlEncoding.GetBytes(s);
        request.ContentLength = s.Length;
        using (var postParams = request.GetRequestStream()) 
        {
            postParams.Write(data, 0, data.Length);
            using (var response = request.GetResponse()) 
            {
                using (var rStream = response.GetResponseStream()) 
                {
                    string r = xmlEncoding.GetString(ReadFully(rStream));
                    //Console.WriteLine(r);
                    return r;
                }
            }
        }
    } 
    catch (WebException e) 
    {
        throw new SolrConnectionException(e);
    }
}
4

1 に答える 1

1

私は、.Net、Solr、または Solr の .Net ポートにあまり詳しくありません。しかし、ここに私の推測があります。

postParams.Write(xmlEncoding.GetBytes(s), 0, s.Length);

考えられるエラーは 2 つあります。

  1. String からバイトを取得する場合は、エンコーディングを指定する必要があります。デフォルトのエンコーディングが、応答のコンテンツ タイプ ヘッダーで設定した UTF8 とは異なる場合があります。
  2. Write() の 3 番目のパラメーターは、おそらく GetBytes() から取得したバイト配列の長さを参照しています。バイト配列は文字列の長さよりも長くなる可能性があります。
于 2009-09-17T10:49:23.407 に答える