PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

SSH2+proxool 出现No suitable driver found for proxool.mysqlP

原创
2016-06-07 15:26:41 946浏览

首先我们要明确使用的是SSH2框架,然而Struts2是基于filter实现的那么在启动proxool的时候就不能够在用servlet来启动了! 于是我们就想到在初始化web容器的时候怎么让他一开始就加载呢? 我们查看tomcat的启动信息: Starting Servlet Engine: Apache Tomcat

首先我们要明确使用的是SSH2框架,然而Struts2是基于filter实现的那么在启动proxool的时候就不能够在用servlet来启动了!

于是我们就想到在初始化web容器的时候怎么让他一开始就加载呢?

我们查看tomcat的启动信息:

 Starting Servlet Engine: Apache Tomcat/6.0.13
2012-6-10 15:31:41 org.apache.catalina.core.ApplicationContext log
信息: Initializing Spring root WebApplicationContext
2012-6-10 15:31:41 org.springframework.web.context.ContextLoader initWebApplicationContext
信息: Root WebApplicationContext: initialization started

最先启动的是spring容器,那么这样我们就可以将proxool的配置写在spring的配置文件中让它最先加载

如下:

	

这样只需要在sessionFactory加上dataSource的引用即可如下:

 	           

这样就不在需要配置proxool的servlet启动了,例如:

     
        ServletConfigurator   
           
            org.logicalcobwebs.proxool.configuration.ServletConfigurator   
           
           
            xmlFile   
            WEB-INF/classes/proxool.xml   
           
        1   
  
 
以上的配置就不在需要在web.xml中进行配置。
而在hibernate.cfg.xml中也不在需要proxool的配置只是配置一些hibernate的信息例如:
	trueorg.hibernate.dialect.MySQLDialect
和一些实体类的映射文件:
 
以上就将SSH2+PROXOOL的环境搭建好了。
 
但是在搭建好之后如果我们配置
 
 
又会提示如下错误:
Invalid property 'houseKeepingSleepTime' of bean class [org.logicalcobwebs.proxool.ProxoolDataSource]: Bean property 'houseKeepingSleepTime' is not writable or has an invalid setter method. Does the parameter type of the setter match the return type of the getter?
大概意思是说'houseKeepingSleepTime'属性是不能够写的或者没有合适的setter方法。在他的参数setter和getter的返回结果类型不一致所导致的。
这个我想也正是他的bug吧。
那么具体解决如下:
在proxool-0.9.1.jar(我用的proxool架包)中找到org.logicalcobwebs.proxool.ProxoolDataSource将其源码修改如下:
 
源码是:
1./**  
2.    * @see ConnectionPoolDefinitionIF#getHouseKeepingSleepTime  
3.    */  
4.   public long getHouseKeepingSleepTime() {   
5.       return houseKeepingSleepTime;   
6.   }   
7.  
8.   /**  
9.    * @see ConnectionPoolDefinitionIF#getHouseKeepingSleepTime  
10.    */  
11.   public void setHouseKeepingSleepTime(int houseKeepingSleepTime) {   
12.       this.houseKeepingSleepTime = houseKeepingSleepTime;   
13.   }  

 
修改为:
  1. /**  
  2.     * @see ConnectionPoolDefinitionIF#getHouseKeepingSleepTime  
  3.     */  
  4.    public long getHouseKeepingSleepTime() {   
  5.        return houseKeepingSleepTime;   
  6.    }   
  7.   
  8.    /**  
  9.     * @see ConnectionPoolDefinitionIF#getHouseKeepingSleepTime  
  10.     *此处将int类型改为long类型  
  11.     */  
  12.    public void setHouseKeepingSleepTime(long houseKeepingSleepTime) {   
  13.        this.houseKeepingSleepTime = houseKeepingSleepTime;   
  14.    }  
这样所有问题都解决!
以上所有步骤都是通过本人在网上查资料,自己手动配置而成。验证通过!
 
 
 

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
上一条:体验mysql 下一条:MySQL的优化