本文使用的软件版本:
tomcat 5.5.15
MySql 5
Eclipse 3.1
正常情况下,配置一个数据库连接池比较简单,主要分3步:
1、在tomcat中配置一个数据源,可以通过tomcat自带的工具进行配置,配置完成后,tomcat的server.xml中会多出如下内容:
<Resource
name="jdbc/mysql"
type="javax.sql.DataSource"
password="123456"
driverClassName="com.mysql.jdbc.Driver"
maxIdle="20"
maxWait="5000"
username="root"
url="jdbc:mysql://localhost/test"
maxActive="10"/>
2、在某个Web应用的web.xml文件中加入如下代码:
<resource-ref>
<res-ref-name>jdbc/mysql</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>
3、在该Web应用的context片段中加入如下代码:
<ResourceLink
name="jdbc/mysql"
type="javax.sql.DataSource"
global="jdbc/mysql"/>
进行以上3处配置后,就可以使用数据库连接池了,具体试验代码如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
<%@ page import="java.sql.*"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>aaaa</h1>
<%
Context ctx=null;
Connection cnn=null;
Statement stmt=null;
ResultSet rs=null;
try
{
ctx=new InitialContext();
if(ctx==null){
out.println("1 wrong");
throw new Exception("11");
}
DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/mysql");
if(ds==null){
out.println("2 wrong");
throw new Exception("22");
}
cnn=ds.getConnection();
stmt=cnn.createStatement();
rs=stmt.executeQuery("select * from student");
rs.next();
out.println(rs.getString(2));
}catch(SQLException e) {
out.println(e.getSQLState());
}
finally
{
if(rs!=null)
rs.close();
if(stmt!=null)
stmt.close();
if(cnn!=null)
cnn.close();
if(ctx!=null)
ctx.close();
}
%>
</body>
</html>
下面探讨一下在Lomboz中使用数据库连接池会出现哪些问题:
最重要的一点,他无法完成第三步配置,因为在Lomboz中启动tomcat时,他不会读取该web应用的context片段,因此,你在context片段中进行的任何配置,对于Lomboz来讲都是无效的,自然也就无法使用数据库连接池了。那么有没有解决办法呢?当然有,让我们来分析一下Lomboz启动tomcat的过程,在Lomboz中配置好一个tomcat服务器后,他会生成一个名叫Servers的项目,该项目和你的其他Eclipse项目位于同一个目录,很好找。进入Servers文件夹,你会看见一个名叫Tomcat v5.5 Server @ localhost-config的文件夹,进入该文件夹你会找到一个server.xml文件,这个文件就是在Lomboz中启动tomcat所用到的配置文件,他不会使用位于tomcat目录下的配置文件。因此要想使你的配置对于Lomboz有效,你就应该修改这个文件。最后再说一点重要的,对这个文件的修改不可以通过一般的编辑软件进行,必须使用Eclipse自带的XML编辑器进行,否则在Lomboz中将无法启动tomcat。
最后给出一个修改好的例子,红色部分为被修改处,仅供参考:
<?xml version="1.0" encoding="UTF-8"?>
<Server>
<Listener className="org.apache.catalina.core.AprLifecycleListener"/>
<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener"/>
<Listener className="org.apache.catalina.storeconfig.StoreConfigLifecycleListener"/>
<Listener className="org.apache.catalina.mbeans.ServerLifecycleListener"/>
<GlobalNamingResources>
<Environment
name="simpleValue"
type="java.lang.Integer"
value="30"/>
<Resource
auth="Container"
description="User database that can be updated and saved"
name="UserDatabase"
type="org.apache.catalina.UserDatabase"
pathname="conf/tomcat-users.xml"
factory="org.apache.catalina.users.MemoryUserDatabaseFactory"/>
<Resource
name="jdbc/mysql"
type="javax.sql.DataSource"
password="123456"
driverClassName="com.mysql.jdbc.Driver"
maxIdle="20"
maxWait="5000"
username="root"
url="jdbc:mysql://localhost/test"
maxActive="10"/>
</GlobalNamingResources>
<Service name="Catalina">
<Connector connectionLinger="-1" connectionTimeout="60000" maxHttpHeaderSize="8192" maxSpareThreads="75" maxThreads="150" minSpareThreads="25" port="80" redirectPort="8443" serverSoTimeout="0" tcpNoDelay="true">
</Connector>
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443">
</Connector>
<Engine defaultHost="localhost" name="Catalina">
<Realm className="org.apache.catalina.realm.UserDatabaseRealm"/>
<Host appBase="webapps" name="localhost">
<Context docBase="E:\java程序\addbook\.deployables\addbook" path="/addbook" privileged="true" reloadable="true">
<ResourceLink
name="jdbc/mysql"
type="javax.sql.DataSource"
global="jdbc/mysql"/>
</Context><Context docBase="E:\java程序\myweb\.deployables\myweb" path="/myweb" reloadable="true" source="com.ibm.wtp.web.server:myweb"/> <Context docBase="E:\java程序\StrutsTest\.deployables\StrutsTest" path="/StrutsTest" reloadable="true" source="com.ibm.wtp.web.server:StrutsTest"/><Context docBase="E:\MyWeb" path="/aa" reloadable="true"/></Host>
</Engine>
</Service>
</Server>
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/andycpp/archive/2006/04/14/663642.aspx
分享到:
相关推荐
Tomcat 中配置数据源原理详解 在本文中,我们将详细介绍在 Tomcat 中配置数据源的原理。数据源是指Java应用程序连接数据库的接口,通过配置数据源,我们可以在 Java 应用程序中访问数据库。 首先, let's talk ...
本篇文章将深入探讨如何在Tomcat中配置数据源,以便于应用程序高效、稳定地访问数据库。 数据源(DataSource)是Java EE中用于管理数据库连接的接口,它提供了一种在多线程环境中安全、有效地管理和重用数据库连接...
### 在Tomcat中配置数据源:深入解析与实践 #### 核心概念解析: **数据源(DataSource)**:在Java EE环境中,数据源是一种管理数据库连接的方式,它提供了访问数据库的标准接口。通过数据源,应用程序可以获取到...
用于在tomcat中配置java数据源用于在tomcat中配置java数据源用于在tomcat中配置java数据源用于在tomcat中配置java数据源用于在tomcat中配置java数据源。
通过以上步骤,开发者可以在IntelliJ IDEA中使用Tomcat自动部署JNDI数据源,实现高效、灵活的数据库连接管理。这对于大型企业级应用来说尤其重要,因为它简化了数据库连接的配置和管理,使得团队协作变得更加顺畅。
TOMCAT8 JNDI对用户名和密码加密
Tomcat 中的 JNDI 数据源是指将数据库连接信息注册到 JNDI 服务器中,以便在应用程序中可以通过 JNDI 名称来获取数据库连接。下面我们将详细介绍 Tomcat 配置 JNDI 数据源的多种方式。 方式一:配置单个应用数据源 ...
通过以上步骤,我们可以在Apache Tomcat环境中轻松地配置Oracle数据源,从而简化数据库连接管理的工作。这种方法不仅能够提高开发效率,还能降低出错率,对于Java Web开发者来说是一项非常实用的技术。希望本文对你...
`resource-ref`标签定义了对资源的引用,其中`res-ref-name`应与`context.xml`中的数据源名称一致,`res-type`指明了资源类型,`res-auth`表明连接的验证由容器(这里是Tomcat)处理。 4. **测试连接**: 创建一...
如果使用Spring框架管理数据源,可以在`applicationContext.xml`中使用JNDI配置数据源。示例代码如下: ```xml <value>java:comp/env/jdbc/source_name ``` - **jndiName**:对应于`server.xml`中定义的...
在Java Web应用中,Tomcat作为一款流行的Servlet容器,提供了数据源连接池的配置功能,以便高效管理和复用数据库连接。本篇文章将详细介绍如何在Tomcat中配置数据源连接池,涉及的主要知识点包括: 1. **数据源配置...
配置Tomcat数据源分为以下几个步骤: 1. **创建JDBC驱动类的JAR文件**:确保你的Tomcat安装目录下的`lib`目录包含了对应数据库的JDBC驱动JAR文件。例如,如果是MySQL,你需要`mysql-connector-java.jar`。 2. **...
标题中的“tomcat数据源JAR”指的是在Apache Tomcat服务器中用于管理数据库连接的数据源配置和相关的库文件。在Java应用服务器中,数据源(DataSource)是用于存储数据库连接的池,它允许应用程序高效地获取和释放...
4. **在Web应用中使用数据源** - 在Java代码中,通过JNDI查找服务获取数据源: ```java Context initContext = new InitialContext(); Context envContext = (Context)initContext.lookup("java:comp/env"); ...
在Java Web应用中,Tomcat作为一款广泛应用的Servlet容器,其数据源连接池配置是确保高效、稳定数据库访问的关键步骤。本篇文章将详细介绍如何在Tomcat中配置数据源连接池,以及涉及的相关jar包文件。 首先,理解...
为了在Tomcat中配置DB2数据源,我们需要正确地引入相应的jar包,确保Tomcat能够与DB2顺利通信。以下是关于"tomcat配置db2数据源jar包"的详细知识点: 1. **JDBC驱动**:首先,理解JDBC(Java Database Connectivity...
总结,配置Tomcat数据源是Java Web应用中非常关键的步骤,它涉及到服务器与数据库之间的通信,合理的配置可以提升系统性能并降低资源消耗。在Tomcat 5.5中,我们通过修改`server.xml`文件来定义数据源,并在JSP页面...
标题中提到的"tomcat-jdbc.jar"和"tomcat-juli.jar"是使用Tomcat-jdbc数据源所必需的两个关键库文件。下面将详细介绍这两个jar包的作用和相关知识点: 1. **tomcat-jdbc.jar**: 这个jar文件包含了Tomcat的JDBC...
总的来说,配置Tomcat数据源涉及多个步骤,包括安装管理插件、配置服务器和应用级别的XML文件,以及正确设置数据库连接参数。每个环节都至关重要,只有确保这些步骤都准确无误,才能实现平稳的数据库连接。
通过上述步骤,我们可以成功地在Tomcat服务器环境下配置SQL Server的数据源,并通过示例代码演示了如何在Java程序中使用配置好的数据源。这对于Java Web开发人员来说是非常实用的知识点,可以帮助他们更高效地管理和...