赛迪网 > IT技术 Java > 架构-与-模式
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

多线程问题导致的JDBMonitor的bug分析

发布时间:2008.02.29 04:55     来源:赛迪网    作者:cownew

以前我一直是用使用数据源的系统测试JDBMonitor,昨天我准备把JDBMonitor嵌入到一个小的jsp留言板中,这个留言板写的非常简单,数据库操作也是connection随取随用、用完了就关这种最简单的形式,这倒是帮助我发现了一个超级大bug。
在记事本运行中常常不规律的DataBaseDBListener的logSQL方法报空指针错误,是在logStatement.setString(1, randomGUID.toString());这一句抛出的,我跟踪到mysql驱动的内部(我使用的是mysql数据库做DataBaseDBListener的输出数据库),发现在setString的实现中会去调用connection的方法,而此时connection已经是null了,所以会报空指针错误。
从其不规律的特点我判断出应该是多线程导致的问题。我跟踪发现,有的时候是先调用DataBaseDBListener的close后logSql才被调用。经过分析找出了问题所在,问题就在DBLogger中内部类LogConsumer的startConsumer方法,这个是修改以前的代码:
for (;;)
 {
  SQLInfo info = (SQLInfo) channel.take();    

  if(info==null)
  {
   ontinue;
  }
  for (int i = 0, n = dbListeners.length; i < n; i++)
  {
   dbListeners[i].logSql(info);
  }

 }


在调用channel.take()以后,这个SQLInfo就从channel中去除了。这时如果DBLogger的方法被调用,那么即使dbListeners[i].logSql(info)仍然在运行,但是DBLogger会认为channel已经空了,所有的dbListeners都可以被close了,而在DataBaseDBListener的close方法中会把输出目标数据库connection关掉,那么此时如果DataBaseDBListener的logSql方法还在调用的话,那么一旦使用这个connection,那么就会出现错误了。
我是如下修改的:
修改BlockedChannel类,去掉其take方法,增加一个peek方法和一个remove方法,peek方法是从channel中查出一个对象,但是不把它从channel中移走,只有调用remove方法后才会被移走。
修改DBLogger中内部类LogConsumer的startConsumer方法为如下:
for (;;)
 {
  SQLInfo info = (SQLInfo) channel.peek();
  if(info==null)
  {
   continue;
  }
  for (int i = 0, n = dbListeners.length; i < n; i++)
  {
   dbListeners[i].logSql(info);
  }
  channel.remove(info);
 }

也就是只有SQLInfo被处理完了,才会从channel中移走。
看来JDBMonitor还是要多多测试多多验证,我近期准备对JDBMonitor进行性能测试,看看有没有并发问题有没有性能问题,不要再急着加新功能了,把这些基础的功能做好再说,否则别人用着用着就出现中断性错误了,那将会是比缺少功能更可怕的事情。一位同事曾经说过一句话:“做的越多错的越多。不要你做的多好,只要把已经做完的东西做的更好就可以了。”,看来确实有一定道理呀。把基本的东西做好再说,否则被人骂不专业就惨了。
         (责任编辑:包春林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· JAVA基础:JSP中监测JVM的内存使用情况 (02-28) · J2SE综合:两种Java容器类List和Set分析 (02-28)
· Java语言深入--抽象类和接口的区别 (02-28) · Java语言深入:浅析Java语言中的内部类 (02-28)
· 对使用jfreechart的源代码进行注释说明 (02-28) · 高级:lucene全文检索应用示例及代码简析 (02-28)
· 使用Spring更好地处理Struts动作 (02-28) · J2SE综合--Java 5.0 多线程编程实践 (02-28)
· 开发框架--Hibernate中各个包的作用 (02-27) · 基础:Java/J2EE中文问题终极解决之道 (02-27)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
· 中小企业网站建设存在弊端 手机实名推波助澜
· CIO应如何克服三个关键错误信念 CIO委屈定理
· 五条黄金准则能够让CIO巧妙加薪 CIO焦虑调查
· 网上书店解决方案 深圳边检指挥中心ITSM项目
  IT博客 ·曾剑秋·项立刚·Java学习·网管
  IT技术论坛 ·开发·网管·安全·数据库·系统