SSH2+proxool 出现No suitable driver found for proxool.mysqlProxool
SSH2+proxool 出现No suitable driver found for proxool.mysqlProxool
首先我们要明确使用的是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的配置文件中让它最先加载
如下:
- <bean id="dataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource">
- <property name="alias" value="mysqlProxool"/>
- <property name="driver" value="com.mysql.jdbc.Driver"/>
- <property name="driverUrl" value="jdbc:mysql://localhost:3306/my_blog_01?characterEncoding=UTF-8"/>
- <property name="user" value="root"/>
- <property name="password" value="123456"/>
- <property name="minimumConnectionCount" value="2"/>
- <property name="maximumConnectionCount" value="10"/>
- <property name="prototypeCount" value="5"/>
- <!-- <property name="houseKeepingSleepTime" value="100000"/> -->
- </bean>
这样只需要在sessionFactory加上dataSource的引用即可如下:
- <bean id="sessionFactory"
- class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
- <property name="configLocation" value="classpath:Hibernate.cfg.xml"/>
- <span style="color:#ff0000;"><property name="dataSource">
- <ref local="dataSource"/>
- </property>
- </span> </bean>
这样就不在需要配置proxool的servlet启动了,例如:
- <servlet>
- <servlet-name>ServletConfigurator</servlet-name>
- <servlet-class>
- org.logicalcobwebs.proxool.configuration.ServletConfigurator
- </servlet-class>
- <init-param>
- <param-name>xmlFile</param-name>
- <param-value>WEB-INF/classes/proxool.xml</param-value>
- </init-param>
- <load-on-startup>1</load-on-startup>
- </servlet>
- 以上的配置就不在需要在web.xml中进行配置。
- 而在hibernate.cfg.xml中也不在需要proxool的配置只是配置一些hibernate的信息例如:
- <pre class="html" name="code"> <property name="show_sql">true</property>
- <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property></pre><pre class="html" name="code">和一些实体类的映射文件:</pre><pre class="html" name="code"> <mapping resource="com/wuda/hibernate/table/users.hbm.xml"/></pre><pre class="html" name="code">以上就将SSH2+PROXOOL的环境搭建好了。</pre><pre class="html" name="code"> </pre><pre class="html" name="code">但是在搭建好之后如果我们配置<property name="houseKeepingSleepTime" value="100000"/></pre><pre class="html" name="code"> </pre><pre class="html" name="code"> </pre><pre class="html" name="code">又会提示如下错误:</pre><pre class="html" name="code">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?</pre><pre class="html" name="code">大概意思是说'houseKeepingSleepTime'属性是不能够写的或者没有合适的setter方法。在他的参数setter和getter的返回结果类型不一致所导致的。</pre><pre class="html" name="code">这个我想也正是他的bug吧。</pre><pre class="html" name="code">那么具体解决如下:</pre><pre class="html" name="code">在proxool-0.9.1.jar(我用的proxool架包)中找到org.logicalcobwebs.proxool.ProxoolDataSource将其源码修改如下:</pre><pre class="html" name="code"> </pre><pre class="html" name="code">源码是:</pre><pre class="java" name="code">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. }
- </pre>
- <pre></pre>
- <pre class="html" name="code"> </pre><pre class="html" name="code">修改为:</pre><pre class="html" name="code"><ol class="dp-j"><li><span><span class="comment">/** </span> </span></li><li><span><span class="comment"> * @see ConnectionPoolDefinitionIF#getHouseKeepingSleepTime </span> </span></li><li><span><span class="comment"> */</span><span> </span></span></li><li><span> </span><span class="keyword">public</span><span> </span><span class="keyword">long</span><span> getHouseKeepingSleepTime() { </span></li><li><span> </span><span class="keyword">return</span><span> houseKeepingSleepTime; </span></li><li><span> } </span></li><li><span> </span></li><li><span> </span><span class="comment">/** </span> </li><li><span><span class="comment"> * @see ConnectionPoolDefinitionIF#getHouseKeepingSleepTime </span> </span></li><li><span><span class="comment"> *此处将int类型改为long类型 </span> </span></li><li><span><span class="comment"> */</span><span> </span></span></li><li><span> </span><span class="keyword">public</span><span> </span><span class="keyword">void</span><span> setHouseKeepingSleepTime(</span><span class="keyword">long</span><span> houseKeepingSleepTime) { </span></li><li><span> </span><span class="keyword">this</span><span>.houseKeepingSleepTime = houseKeepingSleepTime; </span></li><li><span> } </span></li></ol></pre><pre class="html" name="code">这样所有问题都解决!
- </pre><pre class="html" name="code">以上所有步骤都是通过本人在网上查资料,自己手动配置而成。验证通过!</pre><pre class="html" name="code"> </pre><pre class="html" name="code"> </pre><pre class="html" name="code"> </pre>
- <pre></pre>
SSH2+proxool 出现No suitable driver found for proxool.mysqlProxool的更多相关文章
- 使用proxool 连接池:No suitable driver found for proxool
使用proxool连接池时:报错误No suitable driver found for proxool.shide的原因: ①.WEB-INF目录下的lib中没有proxool连接池jar驱动包. ...
- struts2+hibernate+spring简单整合且java.sql.SQLException: No suitable driver 问题解决
最近上j2ee的课,老师要求整合struts2+hibernate+spring,我自己其实早早地有准备弄的,现在都第9个项目了,无奈自己的思路和头绪把自己带坑了,当然也是经验问题,其实只是用myec ...
- Spark on Yarn:java.sql.SQLException: No suitable driver found for jdbc:microsoft:sqlserver://localhost\\db_instance_name:1433;databaseName=db_name
本文只是针对当前特定环境下,出现的问题找不到sqljdbc驱动的案例.具体出现原因,可能是spark版本问题,也可能是集群配置问题. yarn-client方式下: 通过--jars参数指定驱动文件位 ...
- java.sql.SQLException: No suitable driver 问题解决
最近在学习java,用到c3p0数据库连接池,遇到一个很奇怪的现象,用main方法测试是可以正常连接数据库的,但是使用jsp调用代码,就会报如下图的错误! 最下面的java.sql.SQLExcept ...
- java连接mysql :No Suitable Driver Found For Jdbc 解决方法
今天出现编码出现了No suitable driver found for jdbc,又是找遍了网上的资料,基本上都说是以下个问题: 一是:连接URL格式出现了问题(Connection con ...
- No Suitable Driver Found For Jdbc_我的解决方法
转载自:http://www.blogjava.net/w2gavin/articles/217864.html 今天出现编码出现了No suitable driver found for ...
- 出现java.sql.SQLException: No suitable driver的几种解决办法
今天在用C3p0连接MySql数据库 这个时候出现了上面的错误, 一般来说这种错误有3个方向解决 一般都是db的配置的问题 ,一定要小心DB 的配置 八月 19, 2017 8:30:46 下午 co ...
- java.sql.SQLException:No suitable driver found for http://localhost:3306/school
1.错误描述 java.sql.SQLException:No suitable driver found for http://localhost:3306/school 2.错误原因 Class. ...
- 关于mule中使用jdbc时报No Suitable Driver found错误的问题
错误大概信息: Exception in thread "main" org.mule.module.launcher.DeploymentStartException: SQLE ...
随机推荐
- POJ - 2079:Triangle (旋转卡壳,求最大三角形)
Given n distinct points on a plane, your task is to find the triangle that have the maximum area, wh ...
- HihoCoder1445 重复旋律5(后缀自动机)
重复旋律5 时间限制:10000ms 单点时限:2000ms 内存限制:512MB 描述 小Hi平时的一大兴趣爱好就是演奏钢琴.我们知道一个音乐旋律被表示为一段数构成的数列. 现在小Hi想知道一部作品 ...
- 爬虫利器 Puppeteer
http://wintersmilesb101.online/2017/03/24/use-phantomjs-dynamic/ 一起学爬虫 Node.js 爬虫篇(三)使用 PhantomJS ...
- nginx之 nginx-1.9.7 编译安装、理论简介
nginx是一个web网站常用的高性能http和反向代理服务器,其具有较好的并发能力,被网易.百度.腾讯.新浪等网站广泛使用. 一. 理论简介 1.首先弄清楚正向代理和反向代理 正向代理:代理客户端, ...
- Servlet3.0之八:基于Servlet3.0的文件上传@MultipartConfig
在Servlet2.5中,我们要实现文件上传功能时,一般都需要借助第三方开源组件,例如Apache的commons-fileupload组件,在Servlet3.0中提供了对文件上传的原生支持,我们不 ...
- Task Crontab
Crontab 1.查看任务 crontab -l 2.编辑任务 1)对应用户登录后编辑其下的作业 crontab -e 2)删除指定用户任务 crontab -u user -r 3)删除用户下指定 ...
- __align(num) 分析
这几天用2440读写SD卡(FAT32文件系统),定义了个文件信息的数据结构里边数据类型有unsigned char, unsigned int, unsigned long几种,在从SD卡上读取数据 ...
- Celery-4.1 用户指南: Routing Tasks (路由任务)
注意: 像主题和扇出之类的路由概念并不对所有传输介质都可用,请翻阅”传输比较表”. 基础 自动路由 路由最简单的方式是使用 task_create_missing_queues 设置(默认启用). 使 ...
- 11-28 网页基础--JavaScript(DOM)
网页基础 第二部分--HTMLDOM操作 一.定义:htmlDOM是一种面向对象的树的模型,它包含html中的所有元素:通过html可以找到所有包含在dom中的元素. 二.作用: 1.查找html元素 ...
- VC++ 6.0 快捷键
多行注释的快捷键 详细步骤 工具栏上右键-〉Customize-〉“Add-ins and Macro Files”tab页,把SAMPLE前面打上钩-〉“Commands”tab页,Categ ...