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, он завершается с ошибкой:

base {System.InvalidOperationException} = {"Удаленный сервер вернул ошибку: (500) Внутренняя ошибка сервера."}

Когда я смотрю на сервер в журналах для apache, это дает следующую причину:

Неожиданный конец блока ввода в конце

Вот полная трассировка стека:

17 сентября 2009 г. 10:13:53 org.apache.solr.common.SolrException log СЕРЬЕЗНО: com.ctc.wstx.exc.WstxEOFException: неожиданный конец входного блока в конечном теге в [строка, столбец {неизвестный источник} ]: [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);
    }
}

person CraftyFella    schedule 17.09.2009    source источник
comment
Глядя на последнюю версию SolrNet... это исправление уже есть :)   -  person CraftyFella    schedule 17.09.2009
comment
Уф, я думал, что ошибка вернулась :-)   -  person Mauricio Scheffer    schedule 17.09.2009
comment
Я думаю, что используемой нами версии уже 11 месяцев... так что я должен обновить ее до последней версии. Извините, что напугал :)   -  person CraftyFella    schedule 17.09.2009
comment
Привет, какую версию solr.net ты сейчас используешь?   -  person Pavan Kumar N    schedule 16.07.2015
comment
Я использую 0.4.0.2002. Тем не менее я сталкиваюсь с этой проблемой.   -  person Pavan Kumar N    schedule 16.07.2015


Ответы (1)


Я не очень хорошо знаком с .Net, Solr или .Net портом Solr. Но, вот мое предположение.

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

Возможны две ошибки.

  1. Когда вы получаете байты из строки, вы должны указать кодировку. Возможно, кодировка по умолчанию отличается от UTF8, которую вы установили в заголовке типа контента в ответ.
  2. Третий параметр в Write(), вероятно, относится к длине массива байтов, который вы получили от GetBytes(). Массив байтов может быть длиннее, чем длина строки.
person Shashikant Kore    schedule 17.09.2009
comment
Привет... спасибо за предположение... Кодировка - UTF8... Она объявлена ​​в верхней части класса следующим образом: private Encoding xmlEncoding = Encoding.UTF8; - person CraftyFella; 17.09.2009
comment
Эй.. Ваше второе замечание было неудачным. Я только что сделал Fiddler2 для POST, и он пропускает последние 2 цифры XML, поэтому ‹/add› становится ‹/ad Brilliant. Благодарность - person CraftyFella; 17.09.2009
comment
Мужик.. Однажды исправил проблему с длиной.. У меня возникла другая проблема.. Оказывается, установка Solr по умолчанию не принимает символы, отличные от ASCII, как часть запроса.. wiki.apache.org/solr/ Итак, я попытаюсь разобраться. Я обязательно внесу свой вклад вернуться к проекту Solr.Net, чтобы никто больше не столкнулся с этой проблемой. - person CraftyFella; 17.09.2009