在网上搜来的文章,记录下来,方便查找使用【王瑞华-华仔】
终于把数据源的配置和JDNI 使用的示例给跑通了,于是就总结下,也希望给需要这方面的同事带来方便。
JNDI : Java Naming and Directory Interface (JNDI)
JNDI works in concert with other technologies in the Java Platform, Enterprise Edition (Java EE) to organize and locate components in a distributed computing environment.
翻译:JNDI 在Java平台企业级开发的分布式计算环境以组织和查找组件方式与其他技术协调工作。
Tomcat 6.0 的数据源配置
1、在Tomcat中配置:
tomcat 安装目录下的conf的context.xml 的
<Context></Context>中
添加代码如下:
<Resource name="jdbc/tango"
auth="Container"
type="javax.sql.DataSource"
maxActive="20"
maxIdel="10"
maxWait="1000"
username="root"
password="root"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/tango"
>
</Resource>
其中:
name 表示指定的jndi名称
auth 表示认证方式,一般为Container
type 表示数据源床型,使用标准的javax.sql.DataSource
maxActive 表示连接池当中最大的数据库连接
maxIdle 表示最大的空闲连接数
maxWait 当池的数据库连接已经被占用的时候,最大等待时间
username 表示数据库用户名
password 表示数据库用户的密码
driverClassName 表示JDBC DRIVER
url 表示数据库URL地址
示例代码:
Context initContext;
try {
Context context=new InitialContext();
DataSource ds=(DataSource) context.lookup("java:/comp/env/jdbc/tango");
// "java:/comp/env/"是固定写法,后面接的是
//context.xml中的Resource中name属性的值
Connection conn = ds.getConnection();
Statement stmt = conn.createStatement();
ResultSet set = stmt.executeQuery("SELECT id,name,age FROM user_lzy");
while(set.next()){
System.out.println(set.getString("name"));
}
//etc.
} catch (NamingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
同时你需要把你使用的数据驱动jar包放到Tomcat的lib目录下。
如果你使用其他数据源如DBCP数据源,需要在<Resouce> 标签多添加一个属性如:
factory="org.apache.commons.dbcp.BasicDataSourceFactory"当然你也要把DBCP相关jar包放在tomcat的lib目录下。
这样的好处是,以后的项目需要这些jar包,可以共享适合于项目实施阶段。
如果是个人开发阶段一个tomcat下部署多个项目,在启动时消耗时间,同时可能不同项目用到不用数据源带来麻烦。
所以有配置方法2。
2、在项目的中配置:
在WebRoot下面建文件夹META-INF,里面建一个文件context.xml,添加内容和 配置1一样同时加上<Resouce> 标签多添加一个属性如:
factory="org.apache.commons.dbcp.BasicDataSourceFactory"
示例代码也和配置1一样这样做的:
可以把配置需要jar包直接放在WEB-INF的lib里面 和服务器内容无关总后一点:提醒大家,有个同学可能说 tomacat的有DBCP的jar包,确实tomcat把它放了进去,你就认为不用添加DBCP数据源的jar包,也按照上面的配置,100%你要出错。
因为tomcat重新打包了相应的jar,你应该把factory="org.apache.commons.dbcp.BasicDataSourceFactory" 改为factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"
分享到:
相关推荐
总结,配置Tomcat 6.0的数据源(DBCP)和JNDI使用,主要是通过修改服务器和应用的配置文件,然后在代码中利用JNDI查找机制获取数据源,实现数据库连接的高效管理。通过实践和理解这些步骤,可以提升你的Java Web开发...
通过上述步骤,我们可以有效地配置Tomcat 6.0的数据源,以实现对数据库连接的有效管理和高效利用。合理配置数据源不仅能显著提高应用程序的性能,还能减少数据库的负载,提高系统的稳定性。同时,正确处理常见的配置...
在Java应用服务器中,如Tomcat 6.0,配置JNDI(Java Naming and Directory Interface)的DBCP(Database Connection Pool)连接池是管理数据库连接的重要步骤。JNDI是一个标准接口,允许应用程序查找和访问命名服务...
Tomcat 6.0数据库连接池驱动的使用,涉及到的主要知识点包括:数据库连接池的概念与作用,Tomcat内置的数据源实现(DBCP和C3P0),数据源的配置方法,JNDI的使用,以及在Java代码中获取和释放数据库连接。...
3. **JNDI(Java Naming and Directory Interface)**:`jndi.jar`提供了对命名和目录服务的访问,使得应用程序可以查找和绑定资源,比如数据源。 4. **JTA(Java Transaction API)**:`jta.jar`包含了处理分布式...
这里,`name`是数据源的JNDI名称,`auth`指明认证方式,`type`指定数据源类型,`driverClassName`是数据库驱动类名,`url`是数据库URL,`username`和`password`是数据库登录凭证,`maxActive`、`maxIdle`和`maxWait`...
6. **JNDI资源**:TOMCAT支持JNDI(Java Naming and Directory Interface),可以注册和查找资源,如数据源。 7. **热部署**:当WEB-INF目录下的类或资源文件发生改变时,TOMCAT能够自动检测并重新加载应用,无需...
以上就是使用Tomcat 6.0和Oracle数据库配置DBCP连接池的详细步骤。在实际应用中,可能还需要根据系统负载、并发需求等因素调整连接池参数,以达到最佳性能和资源利用率。同时,随着技术的发展,后续版本的Tomcat(如...
我们将分别探讨Tomcat 5.5、5.0以及6.0版本的数据源配置,确保每个步骤都清晰易懂。 ### Tomcat 5.5 数据源配置 Tomcat 5.5中,数据源通常通过JNDI(Java Naming and Directory Interface)来配置。首先,我们需要...
一个简单的tomcat6.0+mysql5.5整合spring3.0和hibernate3.3的一个简单的实例,其中的datasource是tomcat JNDI配置的 type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://...
在Tomcat 6.0中,连接池的改进还包括了对JNDI(Java Naming and Directory Interface)支持的增强,以及对其他数据源实现如C3P0和Apache DBCP的支持。这些改变提供了更好的性能监控、故障诊断和资源管理能力,为...
在Tomcat 6.0这个流行的Java Servlet容器中,JNDI被用来配置和管理应用的数据库连接池。Tomcat支持多种数据库连接池实现,如Apache DBCP、C3P0以及HikariCP等。这些连接池通过JNDI服务注册到Tomcat的Context环境中,...
数据源(DataSource)是Java中访问数据库的一种方式,由Tomcat提供。DataSource对象并不像普通Java类那样直接通过new操作创建,而是通过Java Naming and Directory Interface (JNDI) 来查找和获取。JNDI允许应用在...
总结来说,这个"完整版的数据库连接池应用"涵盖了从设置环境到实现和测试的全过程,包括了IDE集成、应用服务器配置、数据库连接池的选择和配置、分层架构的使用,以及测试验证。对初学者而言,这是一个极好的学习...