Tomcat5.0 连接池 ClassNotFoundException:com.mysql.jdbc.Driver

kkctf 2009-04-21 12:19:40
目前正在初学连接池 发生了个奇怪的问题 使用正常连接jdbc没有问题 但是用连接池就出现ClassNotFoundException:com.mysql.jdbc.Driver 错误
我jar包已经放入工程的lib目录内 请朋友们帮忙

我的部分原文:
java代码中:
try {

// Class.forName("com.mysql.jdbc.Driver");
// con=DriverManager.getConnection("jdbc:mysql://localhost:3306/test","root","root");


InitialContext ic=new InitialContext();
DataSource ds=(DataSource)ic.lookup("java:comp/env/jdbc/dateTest");

con=ds.getConnection();
st=con.createStatement();
rs=st.executeQuery("SELECT * FROM menu");
while(rs.next()){
Item i=new Item(rs.getInt(1),rs.getString(2));
al.add(i);
}
} catch (Exception e) {
e.printStackTrace();
}
结果st=con.createStatement();出错

我的工程名是:dateSource
C:\Program Files\Apache Software Foundation\Tomcat 5.0\conf\Catalina\localhost\dateSource.xml:

<?xml version='1.0' encoding='utf-8'?>
<Context docBase="C:\Program Files\Apache Software Foundation\Tomcat 5.0\webapps\dateSource" path="/dateSource" workDir="work\Catalina\localhost\dateSource">
<Resource name="jdbc/dateTest" type="javax.sql.DataSource"/>

<ResourceParams name="jdbc/dateTest">
<parameter>
<name>maxWait</name>
<value>5000</value>
</parameter>
<parameter>
<name>maxActive</name>
<value>10</value>
</parameter>
<parameter>
<name>password</name>
<value>root</value>
</parameter>
<parameter>
<name>url</name>
<value>jdbc:mysql://localhost:3306/test</value>
</parameter>
<parameter>
<name>driverClassName</name>
<value>com.mysql.jdbc.Driver</value>
</parameter>
<parameter>
<name>maxIdle</name>
<value>2</value>
</parameter>
<parameter>
<name>username</name>
<value>root</value>
</parameter>
</ResourceParams>
</Context>

工程的web.xml中:
<resource-ref>
<res-ref-name>jdbc/dateTest</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

错误信息为:
rg.apache.commons.dbcp.SQLNestedException: Cannot load JDBC driver class 'com.mysql.jdbc.Driver'
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:766)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:540)
at com.wish.dao.ItemDAO.getAll(ItemDAO.java:35)
at com.wish.contorlly.ItemServlet.doGet(ItemServlet.java:30)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:157)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:214)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardContextValve.invokeInternal(StandardContextValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:152)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:118)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:102)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:929)
at org.apache.coyote.tomcat5.CoyoteAdapter.service(CoyoteAdapter.java:160)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:799)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.processConnection(Http11Protocol.java:705)
at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:577)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:683)
at java.lang.Thread.run(Thread.java:619)
Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
at org.apache.catalina.loader.StandardClassLoader.loadClass(StandardClassLoader.java:854)
at org.apache.catalina.loader.StandardClassLoader.loadClass(StandardClassLoader.java:721)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:319)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:760)
... 29 more

我在强调一下:工程的lib目录下有mysql-connector-java-5.0.3-bin.jar
而且在
C:\Program Files\Apache Software Foundation\Tomcat 5.0\webapps\dateSource\WEB-INF\lib也有
mysql-connector-java-5.0.3-bin.jar

为什么还是ClassNotFoundException错误呢??

因为是新人暂无分数 所以请各位现帮忙 谢谢了
...全文
3669 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
baobeizuoshoubuli 2011-10-11
  • 打赏
  • 举报
回复
怎么用啊 不会
my_mgh 2011-08-02
  • 打赏
  • 举报
回复
强大、、、、、、、、、
kkctf 2009-04-22
  • 打赏
  • 举报
回复
对不起 刚刚是我mysql服务器没有打开
后来打开了 现在能够正常运行

在此谢谢各位大大们给我的支持和教育 谢谢拉...
眼泪鼻涕ing....
kkctf 2009-04-22
  • 打赏
  • 举报
回复
Last packet sent to the server was 15 ms ago.)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:855)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:540)
at com.wish.dao.ItemDAO.getAll(ItemDAO.java:35)
at com.wish.contorlly.ItemServlet.doGet(ItemServlet.java:30)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:157)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:214)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardContextValve.invokeInternal(StandardContextValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:152)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:118)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:102)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:929)
at org.apache.coyote.tomcat5.CoyoteAdapter.service(CoyoteAdapter.java:160)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:799)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.processConnection(Http11Protocol.java:705)
at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:577)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:683)
at java.lang.Thread.run(Thread.java:619)
Caused by: com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:

** BEGIN NESTED EXCEPTION **

java.net.SocketException
MESSAGE: java.net.ConnectException: Connection refused: connect

STACKTRACE:

java.net.SocketException: java.net.ConnectException: Connection refused: connect
at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:156)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:276)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:2641)
at com.mysql.jdbc.Connection.<init>(Connection.java:1531)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:266)
at org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:37)
at org.apache.commons.dbcp.PoolableConnectionFactory.makeObject(PoolableConnectionFactory.java:290)
at org.apache.commons.dbcp.BasicDataSource.validateConnectionFactory(BasicDataSource.java:877)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:851)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:540)
at com.wish.dao.ItemDAO.getAll(ItemDAO.java:35)
at com.wish.contorlly.ItemServlet.doGet(ItemServlet.java:30)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:157)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:214)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardContextValve.invokeInternal(StandardContextValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:152)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:118)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:102)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:929)
at org.apache.coyote.tomcat5.CoyoteAdapter.service(CoyoteAdapter.java:160)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:799)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.processConnection(Http11Protocol.java:705)
at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:577)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:683)
at java.lang.Thread.run(Thread.java:619)


** END NESTED EXCEPTION **



Last packet sent to the server was 15 ms ago.
at com.mysql.jdbc.Connection.createNewIO(Connection.java:2707)
at com.mysql.jdbc.Connection.<init>(Connection.java:1531)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:266)
at org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:37)
at org.apache.commons.dbcp.PoolableConnectionFactory.makeObject(PoolableConnectionFactory.java:290)
at org.apache.commons.dbcp.BasicDataSource.validateConnectionFactory(BasicDataSource.java:877)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:851)
... 29 more

还是那句
con=ds.getConnection();
出错
kkctf 2009-04-22
  • 打赏
  • 举报
回复
谢谢上面朋友给我做出的答复
我吧mysql-connector-java-5.0.3-bin.jar文件放入C:\Program Files\Apache Software Foundation\Tomcat 5.0\common\lib后
那个ClassNotFoundException错误是没有了 但是又引发其它的几个错误

org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Communications link failure due to underlying exception:

** BEGIN NESTED EXCEPTION **

java.net.SocketException
MESSAGE: java.net.ConnectException: Connection refused: connect

STACKTRACE:

java.net.SocketException: java.net.ConnectException: Connection refused: connect
at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:156)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:276)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:2641)
at com.mysql.jdbc.Connection.<init>(Connection.java:1531)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:266)
at org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:37)
at org.apache.commons.dbcp.PoolableConnectionFactory.makeObject(PoolableConnectionFactory.java:290)
at org.apache.commons.dbcp.BasicDataSource.validateConnectionFactory(BasicDataSource.java:877)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:851)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:540)
at com.wish.dao.ItemDAO.getAll(ItemDAO.java:35)
at com.wish.contorlly.ItemServlet.doGet(ItemServlet.java:30)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:689)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:157)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:214)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardContextValve.invokeInternal(StandardContextValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:152)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:118)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:102)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:929)
at org.apache.coyote.tomcat5.CoyoteAdapter.service(CoyoteAdapter.java:160)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:799)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.processConnection(Http11Protocol.java:705)
at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:577)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:683)
at java.lang.Thread.run(Thread.java:619)


** END NESTED EXCEPTION **





quanjinzhang 2009-04-21
  • 打赏
  • 举报
回复
估计是tomcat的jndi数据源配置有问题。
yanglingbo 2009-04-21
  • 打赏
  • 举报
回复
把这个文件 mysql-connector-java-5.0.3-bin.jar 复制到 tomcat 的 common/lib 目录下
dxpws 2009-04-21
  • 打赏
  • 举报
回复
关于Tomcat与MySQL连接池问题的详解
转贴:http://www.knowsky.com/344326.html

关于Tomcat与MySQL连接池问题的详解(原创)

  研究了一天,终于有所收获,希望对大家有所帮助。首先请大家注意:这里尤其讨论Tomcat5.5版本中遇到的问题,为什么尤其单对这个版本,我一会儿便加以说明。

  问题一:Cannot create JDBC driver of class '' for connect URL 'null'
  答:
  [原因分析]
  很多朋友在配置好$Tomcat/conf/server.xml、$Tomcat/conf/context.xml、甚至WEB-INF /web.xml后发现调用连接池便会出现以上错误。分析错误原因,一般是因为大家没有邦定数据源(实际错误原因是因为driverClassName、 url的设置为空,但大家肯定不会忘记设置这个地方,所以肯定是大家设置完了没有进行连接!)。通常大家配置数据源有两种方式(在$Tomcat/conf/context.xml的设置方法就不单算了),一种是在$Tomcat/conf/server.xml的< /GlobalNamingResources>前添加如下代码:
  设置方法一:
<Resource
name="jdbc/test" //数据源名称
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver" //这就是我刚才提到的driverClassName的设置
password="admin" //数据库密码
maxIdle="2"
maxWait="5000"
username="root" //数据库用户名
url="jdbc:mysql://localhost:3306/test?autoReconnect=true" //数据库URL,就是刚才提到的url
maxActive="4"/>

  除了有注释的地方外,都是设置连接数目、闲置状况和活动状况的参数,如果你仅是做学习试验,可以不必更改。这种方法配制后的效果等同于在Tomcat图形界面中配置操作。
  另一种发法是在$Tomcat/conf/server.xml的<Context ...></Context>中加入如下代码:
  设置方法二:
<Resource name="jdbc/test" auth="Container" type="javax.sql.DataSource"/>
<ResourceParams name="jdbc/test">
<parameter>
<name>factory</name>
<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
</parameter>
<parameter>
<name>username</name>
<value>root</value>
</parameter>
<parameter>
<name>password</name>
<value>admin</value>
</parameter>
<parameter>
<name>driverClassName</name>
<value>com.mysql.jdbc.Driver</value>
</parameter>
<parameter>
<name>url</name>
<value>jdbc:mysql://localhost:3306/test?autoReconnect=true</value>
</parameter>
<parameter>
<name>initialSize</name>
<value>20</value>
</parameter>
<parameter>
<name>maxActive</name>
<value>30</value>
</parameter>
<parameter>
<name>maxWait</name>
<value>10000</value>
</parameter>
</ResourceParams>

  这样设置的通常目的是想让数据源在一个单独的映射目录中实现,也就是通常这段代码出现在<Context docBase="具体目录(如D:\webapps\myjsp)" path="访问名称(如/myjsp)" reloadable="true"></Context>,这样就可以通过访问http://localhost:8080/myjsp/XXX.jsp来访问D:\webapps\myjsp中的某个jsp页面进而调取数据源或进行其它操作调取数据源。

  问题是,无论哪种方法,大家都没有进行连接!如果不进行ResourceLink,也免或者bean等无法找到你设置的代码,又怎么找到driverClassName和url呢?实际上任何一个参数设置都不会被找到的!

  [解决方法]
  知道了原因,解决也就方便了。无论你是使用哪种方法。
  解决方法一:
  如果想在某个映射目录内实现ResourceLink,就在<Context ...></Context>中间添加<ResourceLink global="数据源名称" name="映射后的名称" type="javax.sql.DataSource"/>,注意如果你不了解代码关联关系,一定紧紧贴在<Context ...>后写就好。
  解决方法二:
  如果想变成全局性的,在所有映射目录中均可以使用,就干脆写在$Tomcat/conf/context.xml中,万事OK了。
  一般大家把“数据源名称”和“映射后的名称”设置成同一个,例如我是这样设置的<ResourceLink global="jdbc/test" name="jdbc/test" type="javax.sql.DataSource"/>。

  另外必须说明,在Tomcat5.5中,如果你像上面第二种设置方法,即使加上ResourceLink,也会遇到不能正常运行的问题。

  问题二:javax.naming.NameNotFoundException: Name XXX is not bound in this Context
  答:
  [原因分析]
  Tomcat5.5中,在<Context ...><Context>中设置数据源不能正常运行,我看过一位外国人写的帖子,我英语水平不高,不过刚好能看懂。他说这是因为比较高的版本中(应该是说Tomcat和dbcp),factory的值由 org.apache.commons.dbcp.BasicDataSourceFactory改为了 org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory。但是我进行过尝试,并不能解决问题。而且我发现Tomcat5.5标准版本自带dbcp,就在$Tomcat\common\lib中。我看过另一个网友的解说,他说用第二种设置方法是不行的。这说明第二种设置方法只适用以前版本,现在的版本我不知道要在哪部分做更改,但错误原因是想一起那么设置,服务器找不到“数据源名称”对应的数据源。
  [解决方法]
  知道原因就可以解决了,看来只有把数据源声明在<GlobalNamingResources>中才能起作用。所以大家就按照第一种设置方法设置Tomcat5.5(这就是我为什么尤其讲Tomcat5.5)就可以了。

  问题三:Cannot load JDBC driver class 'com.mysql.jdbc.Driver'
  答:
  [原因分析]
  不光对于mysql,对于别的数据库,只要找不到,就会抛出这个错误"Cannot load JDBC driver class",那么为什么会找不到数据库驱动类呢?如何才能找到呢?其实很简单。
  [解决方法]
  只要把jdbc拷贝到$Tomcat\common\lib中就可以了。

  问题四:Cannot get a connection, pool exhausted
  [原因分析]
  很简单,不能建立连接,连接池溢出,这说明你的连接资源都浪费了,原因是你没有及时回收它们。
  [解决方法]
  及时并正确使用close()方法释放ResultSet、Statement、Connection,具体语句我就不说了,推荐在finally中写。

  总结:所以,如果你想用Tomcat5.5建立一个数据源连接池,只要三步。

  第一:设置数据源,推荐用图形操作界面,如果手动就在$Tomcat/conf/server.xml中</GlobalNamingResources>前添加如下代码:

<Resource
name="jdbc/test" //数据源名称
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver" //这就是我刚才提到的driverClassName的设置
password="admin" //数据库密码
maxIdle="2"
maxWait="5000"
username="root" //数据库用户名
url="jdbc:mysql://localhost:3306/test?autoReconnect=true" //数据库URL,就是刚才提到的url
maxActive="4"/>

  注释参数记得更改成自己的。

  第二:设置Resource连接。推荐在$Tomcat/conf/context.xml中写入<ResourceLink global="数据源名称" name="映射后的名称" type="javax.sql.DataSource"/>,如果想就在某个单独映射目录实现,就在$Tomcat/conf /server.xml中需要映射的目录中的<Context ...>后写入。

  第三:将JDBC拷贝到$Tomcat\common\lib中

  另外,我在这里不详细说明如何调用数据源,这个问题比较简单,但要注意,DataSource ds=(DataSource)envCtx.lookup("引用数据源");语句中"引用数据源"只的是"映射后的名称",不是"数据源名称",所以我建议大家方便起见把两个名字设成同一个。而且特别要注意及时释放闲置资源,不然连接池就会溢出!
montao 2009-04-21
  • 打赏
  • 举报
回复
你的JNDI配置在tomcat的server.xml里面的么?
那么你的mysql驱动要拷贝一份到tomcat\common\lib目录下一份
dxpws 2009-04-21
  • 打赏
  • 举报
回复
攻破JNDI连接池(Tomcat5.5下通过管理界面配置连接池)
文章录入:7747.Net 责任编辑:7747.Net 更新时间:2008-5-21 23:29:04 215215


【字体:小 大】
攻破JNDI连接池- -

经过几天的努力,终于可以连接上连接池了,其中参考了很多大侠关于这方面的贴子,现在将这几天出现的几个问题写在这里:
一.在tomcat(一个很好用的JSP运行平台)_home\common 下放入jdbc的三个驱动程序(一定要的哦),可以在微软的网站上去下载,安装的SQLSERVER2k默认的用户名是sa,密码是空,但密码为空并不代表没有密码,所以你的url中一定要定义username和password,最好是重设定一下密码
二.出现不能引用错误的话一般就是路径没有写对,tomcat(一个很好用的JSP运行平台)默认的路径是tomcat(一个很好用的JSP运行平台)_home\webapps\不过使用5.5.x的话,按下面方法就行,不需要配置路径,而且也不用在youwebapp\WEB-INF\web.xml(标准化越来越近了)文件配置引用
三.tomcat(一个很好用的JSP运行平台)5.5.x版的server.xml(标准化越来越近了)配置与tomcat(一个很好用的JSP运行平台)5.0的配置不同,下面列举三种在tomcat(一个很好用的JSP运行平台)5.5.x的配置方法,如果配置不正确会出现javax.naming.NameNotFoundException: Name is not bound in this Context 错误
方式一、全局数据库连接池
1、通过管理界面配置连接池,或者直接在tomcat(一个很好用的JSP运行平台)\conf\server.xml(标准化越来越近了)的GlobalNamingResources中增加
<Resource name="jdbc/mydb" type="javax.sql.DataSource" password="mypwd" driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver" maxIdle="2" maxWait="5000" validationQuery="select 1" username="sa" url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb" maxActive="4"/>
2、在tomcat(一个很好用的JSP运行平台)\webapps\myapp\META-INF\context.xml(标准化越来越近了)的Context中增加:
<ResourceLink global="jdbc/mydb" name="jdbc/mydb" type="javax.sql.DataSource"/>
这样就可以了。
方式二、全局数据库连接池
1、同上
2、在tomcat(一个很好用的JSP运行平台)\conf\context.xml(标准化越来越近了)的Context中增加:
<ResourceLink global="jdbc/mydb" name="jdbc/mydb" type="javax.sql.DataSource"/>
方式三、局部数据库连接池
只需在tomcat(一个很好用的JSP运行平台)\webapps\myapps\META-INF\context.xml(标准化越来越近了)的Context中增加:
<Resource name="jdbc/mydb" type="javax.sql.DataSource" password="mypwd" driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver" maxIdle="2" maxWait="5000" validationQuery="select 1" username="sa" url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb" maxActive="4"/>
参数说明:
driveClassName:JDBC驱动类的完整的名称;
maxActive:同时能够从连接池中被分配的可用实例的最大数;
maxIdle:可以同时闲置在连接池中的连接的最大数;
maxWait:最大超时时间,以毫秒计;
password:用户密码;
url:到JDBC的URL连接;
user:用户名称;
validationQuery:用来查询池中空闲的连接。
以上三种方式在tomcat(一个很好用的JSP运行平台) 5.5.4下都可以。另外,sql server(WINDOWS平台上强大的数据库平台)的jdbc driver是从微软网站上下载的sql server(WINDOWS平台上强大的数据库平台) jdbc (sp3)。
四.报错org.apache(Unix平台最流行的WEB服务器平台).tomcat(一个很好用的JSP运行平台).dbcp.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory ([Microsoft][SQLServer 2000 Driver for JDBC]Error establishing socket.)此是一个小问题,因为我的SQLSERVER2K的服务改成手动的,所以每次启动后就要手动的启动SQLSERVER2K,由于一下子不记的启动了,所以报些错误,所以如果你经常要用到SQLSERVER2K的话,最好不要将其改为手动启动
  • 打赏
  • 举报
回复
把这个文件 mysql-connector-java-5.0.3-bin.jar 复制到 tomcat 的 common/lib 目录下,因为 Tomcat 在启动时就得用到。

81,091

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧