Jedis异常
关键字: 异常
最近在用redis出现了很多问题。异常如下:
java.lang.ClassCastException: java.lang.Long cannot be cast to java.util.List at redis.clients.jedis.Connection.getBinaryMultiBulkReply(Connection.java:199) at redis.clients.jedis.Jedis.hgetAll(Jedis.java:851) at redis.clients.jedis.ShardedJedis.hgetAll(ShardedJedis.java:198) |
java.lang.ClassCastException: java.util.ArrayList cannot be cast to [B at redis.clients.jedis.Connection.getBinaryBulkReply(Connection.java:182) at redis.clients.jedis.Connection.getBulkReply(Connection.java:171) at redis.clients.jedis.Jedis.rpop(Jedis.java:1109) at redis.clients.jedis.ShardedJedis.rpop(ShardedJedis.java:258) |
代码里使用了connection pool,后来发现这样的错误前面基本上都是一个
edis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out at redis.clients.jedis.Protocol.process(Protocol.java:79) at redis.clients.jedis.Protocol.read(Protocol.java:131) |
初步怀疑是当前的connection读了部分数据到本地内存中,然后读超时后,并没有把这个connection对应的本地内存数据清空或者destory掉这个connection(有可能直接将该connection正常地return到pool里面了,而不是returnBrokenResource()),然后当前线程或者其他线程继续就用这个connection去做其他的操作,就会导致下次读取来的数据前面还夹杂着上次操作的数据,导致jedis内部无法正确解析成期望的类型。
本文固定链接: http://www.chepoo.com/jedis-exception.html | IT技术精华网
【上一篇】Attribute “scope” must be declared for element type “bean”.
【下一篇】maven项目src/java/main/xml文件在traget class目录不存在
【下一篇】maven项目src/java/main/xml文件在traget class目录不存在