eclipse tomcat JNdi配置笔记

原创 2015年07月08日 11:21:56

一、遇到的错误
1.Name 项目名 is not bound in this Context
2.Name jdbc is not bound in this Context
解决方法:<res-ref-name> 这里写成   jdbc/项目名   </res-ref-name>
3.Cannot create JDBC driver of class '' for connect URL 'null'class '' for connect URL 'null
检查配置:(1)web.xml   (2)tomcat/conf/server.xml

二、具体配置

1.web.xml

<resource-ref>
<span style="white-space:pre">	</span><description>DB Connection</description> 
        <res-ref-name>DingdanManager</res-ref-name> 
        <res-type>javax.sql.DataSource</res-type> 
        <res-auth>Container</res-auth>
</resource-ref>

2.server.xml

<Context docBase="DingdanManager" path="" reloadable="true" source="org.eclipse.jst.j2ee.server:DingdanManager" >
			<Resource auth="Container" name="jdbc/DingdanManager" type="javax.sql.DataSource"/>
				<ResourceParams name="jdbc/DingdanManager">
					<parameter>
						<name>factory</name>
						<value>
							org.apache.commons.dbcp.BasicDataSourceFactory
						</value>
					</parameter>

					<parameter>
						<name>maxActive</name>
						<value>10</value>
					</parameter>

					<parameter>
						<name>maxIdle</name>
						<value>10</value>
					</parameter>

					<parameter>
						<name>maxWait</name>
						<value>10000</value>
					</parameter>

					<parameter>
						<name>driverClassName</name>
						<value>
							com.mysql.jdbc.Driver
						</value>
					</parameter>

					<parameter>
						<name>url</name>
						<value>
							jdbc:mysql://localhost/test
						</value>
					</parameter>

					<parameter>
						<name>validationQuery</name>
						<value>select 1 from dual</value>
					</parameter>

					<parameter>
						<name>testWhileIdle</name>
						<value>true</value>
					</parameter>

					<parameter>
						<name>username</name>
						<value>root</value>
					</parameter>

					<parameter>
						<name>password</name>
						<value>pwd</value>
					</parameter>
				</ResourceParams>
			</Context>

需要注意的是:Context起初是<Context docBase="study" path="" reloadable="true" source="org.eclipse.jst.j2ee.server:study"/>这样的,最后有个/> ,我们写Resource的时候就要去掉/ ,然后在最后补上 </Context>

3.tomcat的lib下要放相应数据库链接的jar包,比如:mysql---mysql-connector-java.jar   Oracle--ojdbc14.jar

4.如果是tomcat5.0 以上的工作就结束了。如果是6.0、7.0,还需要在web项目下的META-INF下放置content.xml

<?xml version="1.0" encoding="UTF-8"?>
<Context>
	<Resource name="jdbc/DingdanManager" 
	auth="Container" 
	type="javax.sql.DataSource" 
	driverClassName="com.mysql.jdbc.Driver"  
	url="jdbc:mysql://localhost/test" 
	username="root" 
	password="root" 
	maxActive="100" 
	maxIdle="10" 
	maxWait="10000"/>
</Context>

三、各参数ss含义

name 表示指定的jndi名称
auth 表示认证方式,一般为Container
type 表示数据源床型,使用标准的javax.sql.DataSource
maxActive 表示连接池当中最大的数据库连接
maxIdle 表示最大的空闲连接数
maxWait 当池的数据库连接已经被占用的时候,最大等待时间
logAbandoned 表示被丢弃的数据库连接是否做记录,以便跟踪
username 表示数据库用户名
password 表示数据库用户的密码
driverClassName 表示JDBC DRIVER
url 表示数据库URL地址
     

四、使用

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;

public class Jndi {
	
	public synchronized static Connection createConn(){
		Connection conn = null;
		try{
			//初始化查找命名空间
		 	Context ctx = new InitialContext(); 
		 	//InitialContext ctx = new InitialContext();亦可 
		 	//找到DataSource,对名称进行定位java:comp/env是必须加的,后面跟你的DataSource名
		 	DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/DingdanManager");
			conn = ds.getConnection();
		} catch (NamingException e) {
		 	System.out.println(e.getMessage());
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return conn;
	}

}






版权声明:本文为博主原创文章,未经博主允许不得转载。

Tomcat配置数据源(JNDI方式)&JDBC(与Oracle的连接)

然后在tomcat目录/conf/server.xml文件里相应的元素,添加如下子元素:
  • sunvsjay1890
  • sunvsjay1890
  • 2016年09月28日 21:51
  • 6374

tomcat下的jndi简单配置

整理版 1.相关包 1、Javax.naming:包含了访问命名服务的类和接口。例如,它定义了Context接口,这是命名服务执行查询的入口。 2、Javax.naming....
  • u011165335
  • u011165335
  • 2016年03月08日 15:58
  • 1277

JNDI数据源(在Tomcat下配置JNDI多数据源实例)

一,添加数据库驱动包加入classpath。 这里我用到了oracle和mysql。 所以由两个jar包:ojdbc14.jar和mysql-connector-java-5.1.13-bin.j...
  • lushuaiyin
  • lushuaiyin
  • 2013年03月20日 14:43
  • 4073

JNDI学习总结(三)——Tomcat下使用Druid配置JNDI数据源

com.alibaba.druid.pool.DruidDataSourceFactory实现了javax.naming.spi.ObjectFactory,可以作为JNDI数据源来配置。 一、...
  • houbin0912
  • houbin0912
  • 2016年09月14日 11:03
  • 3152

Tomcat中配置JNDI数据源详解

JNDI是 Java 命名与目录接口(Java Naming and Directory Interface),在J2EE规范中是重要的规范之一,不少专家认为,没有透彻理解JNDI的意义和作用,就没有...
  • a724888
  • a724888
  • 2017年04月21日 13:27
  • 804

tomcat下jndi的三种配置方式

jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得我们可以用...
  • z69183787
  • z69183787
  • 2014年03月16日 16:58
  • 1410

Tomcat中配置JNDI数据源

准备工作: Tomcat版本:tomcat6.0以上 下例中均使用MySQL数据库 将对应数据源的jar包和MySQL的驱动包拷贝至tomcat的lib文件夹下 一、全局数据源 1步骤一:配置 在to...
  • kris234seth
  • kris234seth
  • 2015年06月30日 13:43
  • 1480

在Tomcat配置JNDI数据源的三种方式

在我过去工作的过程中,开发用服务器一般都是Tomcat 数据源的配置往往都是在applicationContext.xml中配置一个dataSource的bean 然后在部署时再修改JND...
  • Erica_1230
  • Erica_1230
  • 2016年01月15日 19:03
  • 861

在tomcat下context.xml中配置各种数据库连接池(JNDI)

1.   首先,需要为数据源配置一个JNDI资源。我们的数据源JNDI资源应该定义在context元素中。在tomcat6版本中,context元素已经从server.xml文件中独立出来了,放在一个...
  • dangelasir_
  • dangelasir_
  • 2016年09月10日 15:38
  • 2023

什么是jndi,什么时候使用jndi,tomcat配置jndi,spring使用jndi数据源

JNDI 是什么 JNDI是 Java 命名与目录接口(Java Naming and Directory Interface),在J2EE规范中是重要的规范之一,不少专家认为,没有透彻理解JN...
  • u012572955
  • u012572955
  • 2016年08月30日 10:29
  • 1357
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:eclipse tomcat JNdi配置笔记
举报原因:
原因补充:

(最多只允许输入30个字)