2013-09-16 141 views
15

我是Solr的新手。我成功索引了一些数据,但在将日期属性传递给合适的solr字段后,我收到一个异常:Solr'无效日期字符串'异常

我传递了字符串“15.06.2011 13:51:41”,这是一个常见日期格式为像德国这样的国家。然而,经过一些Google搜索之后,我发现Solr预计日期是UTC格式。

我的具体问题是: 我可以在Solr的某个位置将格式转换为UTC吗?这是DateFormatTransformer的情况吗?或者它是否必须最初以正确的格式传递它?

编辑:我没有使用DataImportHandler。我通过将数据直接传递给Solr来使用DirectUpdateHandler2。既然它被称为“直接更新”,那么我的机会在改变任何东西方面都很糟糕吗?

对于记录,我得到的例外是:

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) 

回答

17

按照Solr DateField documentation,需要这样的格式:

日期字段应为形式1995-12-31T23的:59:59Z尾随“Z”表示UTC时间,并且是强制性的(有关UTC的说明,请参阅下文)。可选的小数秒是允许的,只要它们不以尾部0结尾(但任何超过毫秒的精度都将被忽略)。所有其他部分是强制性的。

唯一的选择是在将日期发送到Solr之前转换日期。如果您正在使用DataImportHandler,则可以在该上下文/过程中进行。

+0

感谢您的回复。我正在使用的框架(ManifoldCF)使用DirectUpdateHandler2,而DataImportHandler根本不使用。 在DirectUpdateHandler2调用之前是否有可能实现日期转换?说到Solr当然。 –

+0

鉴于您使用的是DirectUpdateHandler2,从我所能确定的内容来看,在Solr中没有任何方法可以在创建DirectUpdateHandler的自定义版本之后向此进程添加数据转换。我不熟悉ManfioldCF,所以如果在那里有任何选择,我不能提供。 –

+1

据我所知,在ManifoldCF中没有任何优惠(因为这是Connector特定的)。 但是,我会接受你的回答,因为我的问题没有足够的说明。再次感谢您的承诺。 –

相关问题