码迷,mamicode.com
首页 > 其他好文 > 详细

jedis报ClassCastException: [B cannot be cast to XXX

时间:2015-11-06 13:19:01      阅读:702      评论:0      收藏:0      [点我收藏+]

标签:

在代码里对一个值为long类型key执行incrby操作,一直都正常,突发一例异常:

Caused by: java.lang.ClassCastException: [B cannot be cast to java.lang.Long
         at redis.clients.jedis.Connection.getIntegerReply(Connection.java:210)
         at redis.clients.jedis.Jedis.incrBy(Jedis.java:556)
         at com.xxx.xxxxxClient.incrBy(SingleJedisClientImpl.java:119)
         ... 19 common frames omitted

其中com.xxx.xxxxxClient.incrBy是jedis客户端的一个封装和管理。应该是xxxxxClient这里出了问题。再或者是jedis本身线程池管理出了问题。

----------------以下是网上资料,转自http://mengkang.net/443.html---------------------------------------

Caused by: java.lang.ClassCastException: [B cannot be cast to java.util.List  
      at redis.clients.jedis.Connection.getBinaryMultiBulkReply(Connection.java:218) 
      at redis.clients.jedis.Connection.getMultiBulkReply(Connection.java:211)  
      at redis.clients.jedis.Jedis.lrange(Jedis.java:862)  
      at me.topit.site.util.redis.CacheClientBase.lrange(CacheClientBase.java:516)
      at me.topit.site.cache.TagCache.get(TagCache.java:37)
      at me.topit.site.model.Tags.getUserSelectedTags(Tags.java:141)
      at me.topit.site.service.FeedService.getType(FeedService.java:41)
或者
Caused by: java.lang.ClassCastException: java.util.ArrayList cannot be cast to [B
      at redis.clients.jedis.Connection.getBinaryBulkReply(Connection.java:201)
      at redis.clients.jedis.Connection.getBulkReply(Connection.java:190) 
      at redis.clients.jedis.Jedis.hget(Jedis.java:601) 
      at me.topit.site.util.redis.CacheClientBase.hget(CacheClientBase.java:51)
      at me.topit.site.cache.AccountCache.getAuth(AccountCache.java:30)
      at me.topit.site.model.Account.getAuth(Account.java:137)  
      at me.topit.site.service.AccountService.loginCheck(AccountService.java:112)
      at me.topit.site.service.BaseService.isLogin(BaseService.java:87) 
      at me.topit.site.service.PushService.bind(PushService.java:53)

后来发现是因为我做了redis 连接的线程池,使用的一直是一个在父类里申明的静态变量,各个地方调,都是直接用.使用完之后也没有释放.所以每次项目跑着跑着,过几个小时就访问超级慢.最后发现是因为使用的是一个连接的原因. 现在改为每次使用都先初始化,然后每次用完之后都释放.        

------------------------------------------------------------------------------------------------------------

可能是作者提到的这个原因。未确认。

jedis报ClassCastException: [B cannot be cast to XXX

标签:

原文地址:http://my.oschina.net/u/1377774/blog/526850

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!