经过一段艰苦的..........,当然也要感谢WWW提供信息的朋友。
终于把数据源的配置和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
的数据源配置
网上有些资料是5.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 >
<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();
- }
//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"
谢谢大家阅读
********************************************************************************
配制全局数据源时如果是用非tomcap-dbcp(也就是设置了factory属性)则要将引用的数据源和数据库驱动都放到tocmat/lib下
配制单个的webApp时,是在META-INF建一个context.xml文件,当tocmat启动时tocmat会自动在%TOMCAT-HOME%\conf\Catalina\localhost 下生成一个跟webApp同名的.xml文件,内容为context.xml文件里的内容.这个文件以后都不会变(也就是说如果重新发布webApp这个xml文件的内容也不会变,所以当webApp的context.xml文件改动后在发布前先将%TOMCAT-HOME%\conf\Catalina\localhost 下的webApp(名).xml文件先删除为好)