dubbo服务使用spring-data-mongodb进行时间查询的bug记录
生活随笔
收集整理的這篇文章主要介紹了
dubbo服务使用spring-data-mongodb进行时间查询的bug记录
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、項目情況:spring-boot+mongodb+dubbo。
二、問題:調用dubbo服務并使用spring-data-mongodb的gte,lte時間段比較查詢,
@Reference(retries = 1) private FunctionService functionService; //dubbo服務//mongodb gte、lte查詢
Date beginOfToday = DateUtils.getBeginOfToday();
Date endOfToday = DateUtils.getEndOfToday();
Criteria criteria = Criteria.where(Function.FIELD_CREATED_TIME).gte(beginOfToday).lte(endOfToday);
List<Function> todayFunctionList= functionService.find(new Query(criteria));
報錯信息如下:
User: null 系統發生異常java.lang.RuntimeException: org.bson.codecs.configuration.CodecConfigurationException: Can't find a codec for class java.lang.Object. org.bson.codecs.configuration.CodecConfigurationException: Can't find a codec for class java.lang.Object.at org.bson.codecs.configuration.CodecCache.getOrThrow(CodecCache.java:46)at org.bson.codecs.configuration.ProvidersCodecRegistry.get(ProvidersCodecRegistry.java:63)at org.bson.codecs.configuration.ProvidersCodecRegistry.get(ProvidersCodecRegistry.java:37)at com.mongodb.DBObjectCodec.writeValue(DBObjectCodec.java:210)at com.mongodb.DBObjectCodec.encode(DBObjectCodec.java:128)at com.mongodb.DBObjectCodec.encode(DBObjectCodec.java:61)at org.bson.codecs.BsonDocumentWrapperCodec.encode(BsonDocumentWrapperCodec.java:63)at org.bson.codecs.BsonDocumentWrapperCodec.encode(BsonDocumentWrapperCodec.java:29)at org.bson.codecs.EncoderContext.encodeWithChildContext(EncoderContext.java:91)at org.bson.codecs.BsonDocumentCodec.writeValue(BsonDocumentCodec.java:133)at org.bson.codecs.BsonDocumentCodec.encode(BsonDocumentCodec.java:112)at org.bson.codecs.BsonDocumentCodec.encode(BsonDocumentCodec.java:40)at com.mongodb.connection.RequestMessage.addDocument(RequestMessage.java:253)at com.mongodb.connection.RequestMessage.addDocument(RequestMessage.java:205)at com.mongodb.connection.CommandMessage.encodeMessageBodyWithMetadata(CommandMessage.java:75)at com.mongodb.connection.RequestMessage.encodeWithMetadata(RequestMessage.java:160)at com.mongodb.connection.CommandProtocol.sendMessage(CommandProtocol.java:192)at com.mongodb.connection.CommandProtocol.execute(CommandProtocol.java:111)at com.mongodb.connection.DefaultServer$DefaultServerProtocolExecutor.execute(DefaultServer.java:159)at com.mongodb.connection.DefaultServerConnection.executeProtocol(DefaultServerConnection.java:286)at com.mongodb.connection.DefaultServerConnection.command(DefaultServerConnection.java:173)at com.mongodb.operation.CommandOperationHelper.executeWrappedCommandProtocol(CommandOperationHelper.java:215)at com.mongodb.operation.CommandOperationHelper.executeWrappedCommandProtocol(CommandOperationHelper.java:206)at com.mongodb.operation.CommandOperationHelper.executeWrappedCommandProtocol(CommandOperationHelper.java:112)at com.mongodb.operation.FindOperation$1.call(FindOperation.java:487)at com.mongodb.operation.FindOperation$1.call(FindOperation.java:482)at com.mongodb.operation.OperationHelper.withConnectionSource(OperationHelper.java:239)at com.mongodb.operation.OperationHelper.withConnection(OperationHelper.java:212)at com.mongodb.operation.FindOperation.execute(FindOperation.java:482)at com.mongodb.operation.FindOperation.execute(FindOperation.java:79)at com.mongodb.Mongo.execute(Mongo.java:772)at com.mongodb.Mongo$2.execute(Mongo.java:759)at com.mongodb.DBCursor.initializeCursor(DBCursor.java:851)at com.mongodb.DBCursor.hasNext(DBCursor.java:152)at org.springframework.data.mongodb.core.MongoTemplate.executeFindMultiInternal(MongoTemplate.java:1943)at org.springframework.data.mongodb.core.MongoTemplate.doFind(MongoTemplate.java:1763)at org.springframework.data.mongodb.core.MongoTemplate.doFind(MongoTemplate.java:1746)at org.springframework.data.mongodb.core.MongoTemplate.find(MongoTemplate.java:624)at org.springframework.data.mongodb.core.MongoTemplate.find(MongoTemplate.java:615)at ai.deepbrain.iengine.admin.service.impl.base.MongoBaseCrudServiceImpl.find(MongoBaseCrudServiceImpl.java:99)at com.alibaba.dubbo.common.bytecode.Wrapper28.invokeMethod(Wrapper28.java)at com.alibaba.dubbo.rpc.proxy.javassist.JavassistProxyFactory$1.doInvoke(JavassistProxyFactory.java:46)at com.alibaba.dubbo.rpc.proxy.AbstractProxyInvoker.invoke(AbstractProxyInvoker.java:72)at com.alibaba.dubbo.rpc.protocol.InvokerWrapper.invoke(InvokerWrapper.java:53)at com.alibaba.dubbo.rpc.filter.ExceptionFilter.invoke(ExceptionFilter.java:64)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.monitor.support.MonitorFilter.invoke(MonitorFilter.java:75)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.filter.TimeoutFilter.invoke(TimeoutFilter.java:42)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.protocol.dubbo.filter.TraceFilter.invoke(TraceFilter.java:78)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.filter.ContextFilter.invoke(ContextFilter.java:70)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.filter.GenericFilter.invoke(GenericFilter.java:132)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.filter.ClassLoaderFilter.invoke(ClassLoaderFilter.java:38)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.filter.EchoFilter.invoke(EchoFilter.java:38)at com.alibaba.dubbo.rpc.protocol.ProtocolFilterWrapper$1.invoke(ProtocolFilterWrapper.java:91)at com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol$1.reply(DubboProtocol.java:113)at com.alibaba.dubbo.remoting.exchange.support.header.HeaderExchangeHandler.handleRequest(HeaderExchangeHandler.java:84)at com.alibaba.dubbo.remoting.exchange.support.header.HeaderExchangeHandler.received(HeaderExchangeHandler.java:170)at com.alibaba.dubbo.remoting.transport.DecodeHandler.received(DecodeHandler.java:52)at com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable.run(ChannelEventRunnable.java:82)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)at java.lang.Thread.run(Thread.java:748)?
三、本應用中使用gte,lte查詢沒問題
@Autowired private FunctionTagService functionTagService;//本應用的Service//mongodb gte、lte查詢 Date beginOfToday = DateUtils.getBeginOfToday(); Date endOfToday = DateUtils.getEndOfToday(); Criteria criteria = Criteria.where(FunctionType.FIELD_CREATED_TIME).gte(beginOfToday).lte(endOfToday); List<FunctionTag> tagList = functionTagService.find(new Query(criteria));
四、問題分析
先記錄一下問題,猜想是dubbo在序列化gte、lte請求參數時的bug。有空研究....有大神知道的話煩請告知下,多謝。
轉載于:https://www.cnblogs.com/shuaiqing/p/9370031.html
總結
以上是生活随笔為你收集整理的dubbo服务使用spring-data-mongodb进行时间查询的bug记录的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Rpgmakermv(31)MOG插件与
- 下一篇: 密码框