笔者博文:妳那伊抹微笑

博客地址: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. 男性在下一100层【第三层】——高仿手机银行client接口

    前言: 从<男性在下一100层>系列博文[二楼]现在出版了整整三个月后,.从上述观点和这么多朋友的意见还是比较喜欢真实类的博文. 毕竟我们都叫"攻城狮".所以要看是否这 ...

  2. Swift编程语言学习1.4——数值型字面量、数值类型转换

    数值型字面量 整数字面量能够被写作: 一个十进制数,没有前缀 一个二进制数,前缀是0b 一个八进制数,前缀是0o 一个十六进制数,前缀是0x 以下的全部整数字面量的十进制值都是17: let deci ...

  3. JS - 提示是否删除

    1. OnClientClick="return confirm('确定要删除吗?') 2.自定义函数: 函数: <script type ="text/javascript ...

  4. js验证日期

    寻寻觅觅,Web开发里,对日期的验证太多了,网上好多是用正则表达式来验证,但是这种验证也只能验证格式,没办法验证有效性,比如平年(2月28天)和闰年(2月29天).平时用得多,以前经常用一次写一次,腻 ...

  5. BDIA增强

    SE24     CL_EXITHANDLER的方法GET_INSTANCE中有基本上所有的增强都会走这边,打上断点查找增强名称,或者在程序中全局搜索GET_INSTANCE关键字 然后 SE19 下 ...

  6. 适用函数ALSM_EXCEL_TO_INTERNAL_TABLE把excel文件传输到内表中

    FM:ALSM_EXCEL_TO_INTERNAL_TABLE 是上载Excel文件的一个函数,但是这个函数有两个限制. 一是每个CELL只能导入前50个字符,二是如果超过9999行,行号会初始化为从 ...

  7. Net线程安全集合

    在看Supersocket源码的时候发现很多地方都用到了我们不是很常用的线程安全集合,这些都是由net优化后的线程安全集合因此 应该比我们常规lock来效率好一些 比如说: 1 CurrentStac ...

  8. 眼见为实(2):介绍Windows的窗口、消息、子类化和超类化

    眼见为实(2):介绍Windows的窗口.消息.子类化和超类化 这篇文章本来只是想介绍一下子类化和超类化这两个比较“生僻”的名词.为了叙述的完整性而讨论了Windows的窗口和消息,也简要讨论了进程和 ...

  9. 与众不同 windows phone (10) - Push Notification(推送通知)之推送 Tile 通知, 推送自定义信息

    原文:与众不同 windows phone (10) - Push Notification(推送通知)之推送 Tile 通知, 推送自定义信息 [索引页][源码下载] 与众不同 windows ph ...

  10. Linux内核参数信息(Oracle相关)

    命令行:vim  /etc/sysctl.conf 查看如下两行的设置值,这里是: kernel.shmall = 2097152 kernel.shmmax = 4294967295 如果系统默认的 ...