笔者博文:妳那伊抹微笑

博客地址:http://blog.csdn.net/u012185296

博文标题:_00021 妳那伊抹微笑_谁的异常最诡异第二期之 Jedis pool.returnResource(jedis)

个性签名:世界上最遥远的距离不是天涯,也不是海角,而是我站在妳的面前。妳却感觉不到我的存在

技术方向:Flume+Kafka+Storm+Redis/Hbase+Hadoop+Hive+Mahout+Spark ... 云计算技术

转载声明:能够转载, 但必须以超链接形式标明文章原始出处和作者信息及版权声明,谢谢合作!

qq交流群:214293307  (期待与你一起学习,共同进步)

# Redis 谁的问题最诡异第二期

commons-collections-3.2.jar

# 1 Exception in thread "main"java.lang.NoClassDefFoundError: org/apache/commons/collections/CursorableLinkedList

分析:Redis的JavaAPI中Jedis错误,看到这个你肯定会认为这个问题有点低级,确实低级,不用看都知道是少导了jar包引起的。只是这不是重点,重点是Jedis中的一个方法:pool.returnResource(jedis);这个才是重点中的重点。接下来我们看看这种方法的描写叙述:voidredis.clients.util.Pool.returnResource(Jedis
jedis)能够看出这里面并没有抛出异常的声明子类的,那我们就不会去try-catch了,不去try-catch的后果就是会出现莫名其妙的错误。不try-catch会出现一个java.lang.NullPointerExceptio这种空指针异常,这种信息给我们是无用的。这是我们缺少jar包导致的问题。这里却提示java.lang.NullPointerException这种空指针异常,这不是坑爹么?(全然不是我们想要的东西)、、、然后就開始坑爹了。自己開始找错误了,运气差的话找N久也找不出来。有一种怒砸电脑的冲动,运气好的话一下就把错误找出来了,请看以下的代码。不用try-catch跟使用try-catch的比較。饿当时就没使用try-catch。由于这种方法pool.returnResource(jedis);没有声明有异常抛出,所以自然不会用。

(坑爹啊。)

原因:缺少commons-collections-3.2.jar这种jar包

解决:导入commons-collections-3.2.jar该jar包即可了

# 没有使用try-catch的代码已经对应的异常信息

# 没有使用try-catch的代码

publicvoid hdel(String key, String field){

JedisPoolpool =null;

Jedisjedis =null;

try {

pool= getJedisPool(key);

jedis= pool.getResource();

jedis.hdel(key,field);

}catch (Exception e) {

log.error("Redis hdel exception :" + key, e);

pool.returnBrokenResource(jedis);

}finally {

pool.returnResource(jedis);

}

# 异常信息

java.lang.NullPointerException

atcn.adsit.iva.preroll.dp.synch.analysis.redis.util.ConsistentHashRedisUtils.hset(ConsistentHashRedisUtils.java:164)

atcn.adsit.iva.preroll.dp.synch.analysis.UserBehaviorStoreRedis.userBehavior2Redis(UserBehaviorStoreRedis.java:58)

atcn.adsit.iva.preroll.dp.synch.analysis.UserBehaviorAnalysisMainClass.main(UserBehaviorAnalysisMainClass.java:33)

# 使用了try-catch的代码

public void hdel(String key, String field) {

JedisPool pool =null;

Jedis jedis =null;

try {

pool = getJedisPool(key);

jedis = pool.getResource();

jedis.hdel(key, field);

}
catch
(Exception e) {

log.error("Redis hdel exception : " +key, e);

pool.returnBrokenResource(jedis);

}
finally
{


try
{

pool.returnResource(jedis);

}catch(Exception e) {

log.error("JdisreturnResource exception : ", e);

}

}

# 异常信息

[2014-07-1016:39:17,659].[ERROR].[cn.adsit.iva.preroll.dp.synch.analysis.redis.util.ConsistentHashRedisUtils]

JdisreturnResource exception :

java.lang.NullPointerException

atcn.adsit.iva.preroll.dp.synch.analysis.redis.util.ConsistentHashRedisUtils.hset(ConsistentHashRedisUtils.java:164)

atcn.adsit.iva.preroll.dp.synch.analysis.UserBehaviorStoreRedis.userBehavior2Redis(UserBehaviorStoreRedis.java:58)

atcn.adsit.iva.preroll.dp.synch.analysis.UserBehaviorAnalysisMainClass.main(UserBehaviorAnalysisMainClass.java:33)

Exception in thread"main" java.lang.NoClassDefFoundError:org/apache/commons/collections/CursorableLinkedList

atorg.apache.commons.pool.impl.GenericObjectPool.<init>(GenericObjectPool.java:392)

atorg.apache.commons.pool.impl.GenericObjectPool.<init>(GenericObjectPool.java:275)

atredis.clients.util.Pool.<init>(Pool.java:14)

atredis.clients.jedis.JedisPool.<init>(JedisPool.java:24)

atredis.clients.jedis.JedisPool.<init>(JedisPool.java:29)

atcn.adsit.iva.preroll.dp.synch.analysis.redis.util.ConsistentHashRedisUtils.getJedisPool(ConsistentHashRedisUtils.java:343)

atcn.adsit.iva.preroll.dp.synch.analysis.redis.util.ConsistentHashRedisUtils.getJedisPool(ConsistentHashRedisUtils.java:317)

atcn.adsit.iva.preroll.dp.synch.analysis.redis.util.ConsistentHashRedisUtils.hset(ConsistentHashRedisUtils.java:156)

atcn.adsit.iva.preroll.dp.synch.analysis.UserBehaviorStoreRedis.userBehavior2Redis(UserBehaviorStoreRedis.java:58)

atcn.adsit.iva.preroll.dp.synch.analysis.UserBehaviorAnalysisMainClass.main(UserBehaviorAnalysisMainClass.java:33)

Caused by:java.lang.ClassNotFoundException:org.apache.commons.collections.CursorableLinkedList

atjava.net.URLClassLoader$1.run(URLClassLoader.java:217)

atjava.security.AccessController.doPrivileged(Native Method)

atjava.net.URLClassLoader.findClass(URLClassLoader.java:205)

atjava.lang.ClassLoader.loadClass(ClassLoader.java:319)

atjava.lang.ClassLoader.loadClass(ClassLoader.java:264)

atjava.lang.ClassLoader.loadClassInternal(ClassLoader.java:332)

... 10more

}

# 总结1

对照能够知道。使用try-catch之后能够看到原来看不到的更重要的异常信息:Caused by: java.lang.ClassNotFoundException:org.apache.commons.collections.CursorableLinkedList

。然后我们就知道是导入commons-collections-3.2.jar这种jar包了。然后就搞定了,不解释,一个坑爹的问题。缺少jar包,也能够说是自己粗心吧!

希望能够帮到也碰到这样问题的朋友、、、

# Time:2014-07-10 17:35:21

版权声明:本文博客原创文章,博客,未经同意,不得转载。

_00021 尼娜抹微笑伊拉克_谁的的最离奇的异常第二阶段 Jedis pool.returnResource(jedis)的更多相关文章

  1. _00024 尼娜抹微笑伊拉克_云计算ClouderaManager以及CHD5.1.0群集部署安装文档V1.0

    笔者博文:妳那伊抹微笑 itdog8 地址链接 : http://www.itdog8.com(个人链接) 博客地址:http://blog.csdn.net/u012185296 博文标题:_000 ...

  2. _00020 妳那伊抹微笑_谁的异常最诡异第一期之 SqlServer RSA premaster secret error

    博文作者:妳那伊抹微笑 博客地址:http://blog.csdn.net/u012185296 博文标题:_00020 妳那伊抹微笑_谁的异常最诡异第一期之 SqlServer RSA premas ...

  3. HBase - 计数器 - 计数器的介绍以及使用 | 那伊抹微笑

    博文作者:那伊抹微笑 csdn 博客地址:http://blog.csdn.net/u012185296 itdog8 地址链接 : http://www.itdog8.com/thread-215- ...

  4. HBase - Filter - 过滤器的介绍以及使用 | 那伊抹微笑

    博文作者:那伊抹微笑 csdn 博客地址:http://blog.csdn.net/u012185296 itdog8 地址链接 : http://www.itdog8.com/thread-214- ...

  5. C# 语言规范_版本5.0 (第16章 异常)

    1. 异常 C# 中的异常用于处理系统级和应用程序级的错误状态,它是一种结构化的.统一的和类型安全的处理机制.C# 中的异常机制非常类似于 C++ 的异常机制,但是有一些重要的区别: 在 C# 中,所 ...

  6. 读书笔记_Effective_C++_条款二十九:为“异常安全”而努力是值得的

    还是举书上的例子: void PrettyMenu::changeBackground(std::istream& imgSrc) { lock(&mutex); delete bgI ...

  7. _00013 一致性哈希算法 Consistent Hashing 新的讨论,并出现相应的解决

    笔者博文:妳那伊抹微笑 博客地址:http://blog.csdn.net/u012185296 个性签名:世界上最遥远的距离不是天涯,也不是海角,而是我站在妳的面前.妳却感觉不到我的存在 技术方向: ...

  8. Redis_Jedis使用总结

    目录:1.pipeline2.跨jvm的id生成器3.跨jvm的锁实现(watch multi)4.redis分布式 1. Pipeline 官方的说明是:starts a pipeline,whic ...

  9. Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】(转)

    前段时间细节的了解了Jedis的使用,Jedis是redis的java版本的客户端实现.本文做个总结,主要分享如下内容: [pipeline][分布式的id生成器][分布式锁[watch][multi ...

随机推荐

  1. Visual Studio2013创建、公布监控Windows Azure网站

    原文 Visual Studio2013创建.公布监控Windows Azure网站 随着Visual Studio 2013的发布,现在我们可以在Visual Studio内部实现Windows A ...

  2. perl 改变对象属性

    [root@wx03 test]# cat Critter.pm package Critter; #unshift(@INC,"/root/test"); #use messag ...

  3. C keyword register 并讨论共同使用嵌入式汇编

    C keyword register 并讨论共同使用嵌入式汇编 register 是C99 的keyword之中的一个. register 是储存类型之中的一个.这里仅讨论register 储存类型. ...

  4. robotframework ride 版本兼容问题

    在安装robotFramework ride的时候,必须需要使用wxpython 目前使用的wxpython 还必须是unicode 版本的要不然不支持中文 目前使用的 wx.version.2.8. ...

  5. Windows 8 动手实验系列教程 实验8:Windows应用商店API

    动手实验 实验 8: Windows应用商店API 2012年9月 简介 编写Windows应用商店应用最令人瞩目的理由之一是您可以方便地将它们发布到Windows应用商店.考虑到世界范围内目前有超过 ...

  6. Oracle表连接总结

    1 简述 1) 两个表的连接,是通过将一个表中的一列或者多列同另一个表中的列链接而建立起来的.用来连接两张表的表达式组成了连接条件.当连接成功后,第二张表中的数据就同第一张表连接起来了,并形成了复合结 ...

  7. 【Demo 0011】多媒体播放器

    本章学习要点:       1.  掌握AVAudioPlayer 基本使用;       2.  掌握AVPlayer 基本使用;       3.  掌握系统声音播放以及震动;       4. ...

  8. Java常用代码段 - 未完待续

    记录一些自己写项目常用的代码段. 格式化常用日期格式 Date date = new Date(System.currentTimeMillis()); DateFormat d3 = DateFor ...

  9. (一)----使用HttpClient发送HTTP请求(通过get方法获取数据)

    (一)----使用HttpClient发送HTTP请求(通过get方法获取数据) 一.HTTP协议初探: HTTP(Hypertext Transfer Protocol)中文 “超文本传输协议”,是 ...

  10. Servlet API中文版

    基本类和接口 一.javax.servlet.Servlet接口 servlet抽象集是javax.servlet.Servlet接口,它规定了必须由Servlet类实现由servlet引擎识别和管理 ...