2013-09-16 14 views
15

Sono nuovo di Solr. Ho indicizzato con successo alcuni dati, ma dopo aver passato un attributo data a un campo solr appropriato sto ricevendo un'eccezione:Solr 'String Data non valida' Eccezione

Sto passando la stringa "15.06.2011 13:51:41", che è una data comune formato per paesi come la Germania. Tuttavia, dopo alcuni googling che ho scoperto, Solr si aspetta che una data sia nel formato UTC.

La mia domanda specifica è: Posso trasformare il mio formato in UTC ad un certo punto in Solr? Questo sarebbe un caso per DateFormatTransformer o è un MUST per passarlo inizialmente nel formato corretto?

MODIFICA: non sto utilizzando un DataImportHandler. Sto usando DirectUpdateHandler2 passando i dati direttamente a Solr. Dal momento che si chiama "aggiornamento diretto", le mie possibilità sono piuttosto negative nel trasformare qualcosa lì?

Per la cronaca, l'eccezione ho ottenuto è stato:

ERROR - 2013-09-13 15:52:07.705; org.apache.solr.common.SolrException; org.apache.solr.common.SolrException: Invalid Date String:'15.06.2011 13:51:41' 
    at org.apache.solr.schema.DateField.parseMath(DateField.java:182) 
    at org.apache.solr.schema.TrieField.createField(TrieField.java:616) 
    at org.apache.solr.schema.TrieField.createFields(TrieField.java:655) 
    at org.apache.solr.schema.TrieDateField.createFields(TrieDateField.java:157) 
    at org.apache.solr.update.DocumentBuilder.addField(DocumentBuilder.java:47) 
    at org.apache.solr.update.DocumentBuilder.toDocument(DocumentBuilder.java:118) 
    at org.apache.solr.update.AddUpdateCommand.getLuceneDocument(AddUpdateCommand.java:73) 
    at org.apache.solr.update.DirectUpdateHandler2.addDoc(DirectUpdateHandler2.java:210) 
    at org.apache.solr.update.processor.RunUpdateProcessor.processAdd(RunUpdateProcessorFactory.java:69) 
    at org.apache.solr.update.processor.UpdateRequestProcessor.processAdd(UpdateRequestProcessor.java:51) 
    at org.apache.solr.update.processor.DistributedUpdateProcessor.doLocalAdd(DistributedUpdateProcessor.java:556) 
    at org.apache.solr.update.processor.DistributedUpdateProcessor.versionAdd(DistributedUpdateProcessor.java:692) 
    at org.apache.solr.update.processor.DistributedUpdateProcessor.processAdd(DistributedUpdateProcessor.java:435) 
    at org.apache.solr.update.processor.LogUpdateProcessor.processAdd(LogUpdateProcessorFactory.java:100) 
    at org.apache.solr.handler.extraction.ExtractingDocumentLoader.doAdd(ExtractingDocumentLoader.java:121) 
    at org.apache.solr.handler.extraction.ExtractingDocumentLoader.addDoc(ExtractingDocumentLoader.java:126) 
    at org.apache.solr.handler.extraction.ExtractingDocumentLoader.load(ExtractingDocumentLoader.java:228) 
    at org.apache.solr.handler.ContentStreamHandlerBase.handleRequestBody(ContentStreamHandlerBase.java:74) 
    at org.apache.solr.handler.RequestHandlerBase.handleRequest(RequestHandlerBase.java:135) 
    at org.apache.solr.core.RequestHandlers$LazyRequestHandlerWrapper.handleRequest(RequestHandlers.java:241) 
    at org.apache.solr.core.SolrCore.execute(SolrCore.java:1904) 
    at org.apache.solr.servlet.SolrDispatchFilter.execute(SolrDispatchFilter.java:659) 
    at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:362) 
    at org.apache.solr.servlet.SolrDispatchFilter.doFilter(SolrDispatchFilter.java:158) 
    at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1419) 
    at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:455) 
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137) 
    at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:557) 
    at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231) 
    at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1075) 
    at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:384) 
    at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193) 
    at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1009) 
    at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135) 
    at org.eclipse.jetty.server.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:255) 
    at org.eclipse.jetty.server.handler.HandlerCollection.handle(HandlerCollection.java:154) 
    at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116) 
    at org.eclipse.jetty.server.Server.handle(Server.java:368) 
    at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:489) 
    at org.eclipse.jetty.server.BlockingHttpConnection.handleRequest(BlockingHttpConnection.java:53) 
    at org.eclipse.jetty.server.AbstractHttpConnection.headerComplete(AbstractHttpConnection.java:942) 
    at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.headerComplete(AbstractHttpConnection.java:1004) 
    at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:636) 
    at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:235) 
    at org.eclipse.jetty.server.BlockingHttpConnection.handle(BlockingHttpConnection.java:72) 
    at org.eclipse.jetty.server.bio.SocketConnector$ConnectorEndPoint.run(SocketConnector.java:264) 
    at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608) 
    at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543) 
    at java.lang.Thread.run(Unknown Source) 

risposta

17

Secondo il Solr DateField documentation, questo formato è necessario:

campo data deve essere della forma 1995-12-31T23 : 59: 59Z Il trattino "Z" indica l'ora UTC ed è obbligatorio (vedere sotto per una spiegazione di UTC). Sono permessi i frazionari secondi facoltativi, a condizione che non finiscano in uno zero finale (ma qualsiasi precisione oltre i millisecondi sarà ignorata). Tutte le altre parti sono obbligatorie.

L'unica opzione è quella di trasformare la data prima dell'invio in Solr. Se stai usando DataImportHandler, sarebbe possibile all'interno di quel contesto/processo.

+0

Grazie per la risposta. Il framework che sto utilizzando (ManifoldCF) utilizza DirectUpdateHandler2 e DataImportHandler non viene utilizzato affatto. Esiste la possibilità di ottenere una trasformazione della data prima della chiamata DirectUpdateHandler2? A proposito di Solr, ovviamente. –

+0

Dato che si sta utilizzando DirectUpdateHandler2, da quello che posso determinare, non c'è alcun modo in Solr per aggiungere una trasformazione dati a questo processo, a meno di creare una versione personalizzata di DirectUpdateHandler. Non ho familiarità con ManfioldCF, quindi non posso offrire se ci fossero delle opzioni al suo interno. –

+1

Per quanto posso dire, non ci sono offerte in ManifoldCF su questo (poiché questo è specifico del Connector). Tuttavia, accetterò la tua risposta, poiché non ho chiarito abbastanza nella mia domanda. Grazie ancora per il tuo impegno. –

Problemi correlati