Solr-“追加”を投稿する際のエラーサーバーへ
質問
以下を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に到達すると、次のエラーで失敗しました:
ベース {System.InvalidOperationException} = {&quot;リモートサーバーがエラーを返しました: (500)内部サーバーエラー。&quot;}
Apacheのログでサーバーを見ると、次の理由があります:
予期しない入力ブロックの終わりが終わり
完全なスタックトレースは次のとおりです。
2009年9月17日10:13:53 AM org.apache.solr.common.SolrException 重大ログ: 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.wstx.sr.StreamScanner.getNextCharFromCurrent(StreamScanner.java:811) で com.ctc.wstx.sr.BasicStreamReader.readEndElem(BasicStreamReader.java:3211) で 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.core.StandardContextValve.invoke(StandardContextValve.java:191) で org.apache.catalina.core.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) で org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:859) で 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)
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);
}
}
解決
Solrの.NetまたはSolrまたは.Netポートについてはあまり詳しくありません。しかし、ここに私の推測があります。
postParams.Write(xmlEncoding.GetBytes(s), 0, s.Length);
2つのエラーが考えられます。
- 文字列からバイトを取得するときは、エンコーディングを指定する必要があります。デフォルトのエンコードが、応答でコンテンツタイプヘッダーに設定したUTF8と異なる場合があります。
- Write()の3番目のパラメーターは、おそらくGetBytes()から取得したバイト配列の長さを指します。バイト配列は文字列の長さよりも長くなる可能性があります。