由proxool连接池所引发的惨案

使用Proxool数据源连接数据库程序执行第一条查询语句可以查询到数据,接着往下执行查询语句就报java.lang.NullPointerException异常,使用c3p0数据源 没有问题,不使用数据源也没有问题. 
我执行查询时候是使用的Query q=super.getSession().createQuery("from table");难道是由于连接没有释放导致的? 
proxool版本是:0.090-CR2 

cglib-nodep版本是:2.1_3 


proxool配置如下: 

proxool.xml文件:

<?xml version="1.0" encoding="UTF-8"?>

  1. <something-else-entirely>  
  2. <proxool-config>  
  3.   <proxool>  
  4.   <alias>DBPool</alias>  
  5.   <driver-url>jdbc:mysql://localhost:3306/dbab?useUnicode=true&characterEncoding=GBK</driver-url>  
  6.   <driver-class>com.mysql.jdbc.Driver</driver-class>  
  7.   <driver-properties>  
  8.   <property name="user" value="aaa" />  
  9.   <property name="password" value="111111" />  
  10.   </driver-properties>  
  11.   <house-keeping-sleep-time>10000</house-keeping-sleep-time>  
  12.   <maximum-new-connections>20</maximum-new-connections>  
  13.   <prototype-count>5</prototype-count>  
  14.   <maximum-connection-count>100</maximum-connection-count>  
  15.   <minimum-connection-count>10</minimum-connection-count>  
  16.   <house-keeping-test-sql>select CURRENT_DATE</house-keeping-test-sql>  
  17.   </proxool>  
  18. </proxool-config>  
  19. </something-else-entirely> 



applicationContext.xml文件
  1. <bean id="sessionFactory"
  2.   class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
  3.    
  4.   <property name="hibernateProperties">
  5.   <props>
  6.   <prop key="hibernate.dialect">
  7.   org.hibernate.dialect.MySQLDialect
  8.   </prop>
  9.   <prop key="hibernate.show_sql">false</prop>
  10.   <prop key="hibernate.generate_statistics">true</prop>  
  11.   <prop key="hibernate.cglib.use_reflection_optimizer">true</prop>  
  12.   <prop key="hibernate.proxool.xml">proxool.xml</prop>  
  13.   <prop key="hibernate.proxool.pool_alias">DBPool</prop>  
  14.   <prop key="hibernate.connection.release_mode">auto</prop>  
  15.   </props>
  16.   </property>
  17.   </bean>
直接通过datasource在applicationContext.xml配置如下: 
  1. <bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource" destroy-method="close">
  2.   <property name="driver" value="com.mysql.jdbc.Driver"/>
  3.   <property name="driverUrl" value="jdbc:mysql://localhost:3306/dbab?useUnicode=true&characterEncoding=GBK"/>
  4.   <property name="user" value="aaa"/>
  5.   <property name="password" value="111111"/>
  6.   <property name="maximumConnectionCount" value="25"/>
  7.   <property name="minimumConnectionCount" value="5"/>
  8.   <property name="maximumActiveTime" value="1000"/>
  9.   <property name="delegateProperties" value="user=aaa,password=111111"/>
  10.   </bean>

通过加载log4j日志文件发现问题的根本

报错的部分代码

  1. 2008-09-08 13:54:03,812 WARN [net.sf.ehcache.config.Configurator] - No configuration found. Configuring ehcache from ehcache-failsafe.xml found in the classpath: jar:file:/C:/Program%20Files/Apache%20Software%20Foundation/Tomcat%206.0/webapps/KYPro2/WEB-INF/lib/ehcache-1.1.jar!/ehcache-failsafe.xml
  2. 2008-09-08 13:54:05,203 ERROR [org.hibernate.proxy.BasicLazyInitializer] - CGLIB Enhancement failed: com.ky.hibernate.vo.Userdata
  3. java.lang.ExceptionInInitializerError
  4.     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  5.     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
  6.     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  7.     at java.lang.reflect.Method.invoke(Method.java:585)
  8.     at net.sf.cglib.proxy.Enhancer.setCallbacksHelper(Enhancer.java:586)
  9.     at net.sf.cglib.proxy.Enhancer.setThreadCallbacks(Enhancer.java:579)

ehcache-failsafe.xml发现这个文件确实存在,

试着在WEB-INF建立文件ehcache.xml配置文件一样报错,又以为是ehcache版本的问题下载了一个1.2.4版本的jar包结果还是报错.

基本上可以肯定应该不是ehcache包的问题了,接着看下面另外一句错误 CGLIB Enhancement failed 百度了一下发现整个工程中存在两个cglib包一个是hibernate自带的cglib-2.2.jar包一个是spring自带的cglib-nodep.jar包去掉其中的hibernate自带的那个包,还有就是spring自带的asm-2.2.2.jar asm-commons-2.2.2.jar asm-util-2.2.2.jar 与Hibernate自带的asm.jar asm-attrs.jar 其中asm-2.2.2.jar与asm.jar存在类上的冲突!!去掉asm-attrs.jar包即可.

由于这两个包所引发的报错还可能是

  1. 2008-09-08 15:14:47,609 ERROR [org.springframework.web.struts.ContextLoaderPlugIn] - Context initialization failed
  2. org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/classes/applicationContext.xml]: Initialization of bean failed; nested exception is java.lang.NoClassDefFoundError: edu/emory/mathcs/backport/java/util/concurrent/BlockingQueue
  3. java.lang.NoClassDefFoundError: edu/emory/mathcs/backport/java/util/concurrent/BlockingQueue
  4.     at net.sf.ehcache.config.ConfigurationHelper.createCache(ConfigurationHelper.java:418)
  5.     at net.sf.ehcache.config.ConfigurationHelper.createDefaultCache(ConfigurationHelper.java:334)
  6.     at net.sf.ehcache.CacheManager.configure(CacheManager.java:306)
  7.     at net.sf.ehcache.CacheManager.init(CacheManager.java:226)
总结:问题解决办法 去掉
asm-attrs.jar
cglib-2.1.3.jar
加入
cglib-nodep-2.1_3.jar

附带下载地址:http://sourceforge.net/project/showfiles.php?group_id=56933&package_id=98218&release_id=601998


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值