Ytl's Java Blog

厚积而薄发---每一天都是一个全新的开始
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

Tomcat 6.0配置数据源(DBCP)和JNDI使用

Posted on 2009-04-14 17:10 ytl 阅读(8058) 评论(6)  编辑  收藏 所属分类: 学习总结

 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地址


同时你需要把你使用的数据驱动jar包放到Tomcat的lib目录下。
如果你使用其他数据源如DBCP数据源,需要在<Resouce 标签多添加一个属性如
  factory="org.apache.commons.dbcp.BasicDataSourceFactory"
当然你也要把DBCP相关jar包放在tomcat的lib目录下。

这样的好处是,以后的项目需要这些jar包,可以共享适合于项目实施阶段。
如果是个人开发阶段一个tomcat下部署多个项目,在启动时消耗时间,同时
可能不同项目用到不用数据源带来麻烦。所以有配置方法2

2在项目的中配置:

2.1  使用自己的DBCP数据源
在WebRoot下面建文件夹META-INF,里面建一个文件context.xml,
添加内容和 配置1一样
同时加上<Resouce 标签多添加一个属性如
 factory="org.apache.commons.dbcp.BasicDataSourceFactory"


这样做的:可以把配置需要jar包直接放在WEB-INF的lib里面 和web容器(Tomcat)无关

总后一点:提醒大家,有个同学可能说 tomacat的有DBCP的jar包,确实tomcat把它放了
进去,你就认为不用添加DBCP数据源的jar包,也按照上面的配置,100%你要出错。
因为tomcat重新打包了相应的jar,你应该把 
factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory" 改为
  factory="org.apache.commons.dbcp.BasicDataSourceFactory"
  

同时加上DBCP 所依赖的jar包(commons-dbcp.jar和commons-pool.jar)
你可以到www.apache.org 项目的commons里面找到相关的内容

2.2 使用Tomcat 自带的DBCP数据源

在WebRoot下面建文件夹META-INF,里面建一个文件context.xml,
添加相应的内容
这是可以不需要添加配置
配置1一样
 factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"

也不要想添加额外的jar包

最后,不管使用哪种配置,都需要把数据库驱动jar包放在目录tomcat /lib里面

JNDI使用示例代码:

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();
}

谢谢!

评论

# re: Tomcat 6.0配置数据源(DBCP)和JNDI使用[未登录]  回复  更多评论   

2009-04-14 21:06 by java爱好者
好!

# re: Tomcat 6.0配置数据源(DBCP)和JNDI使用[未登录]  回复  更多评论   

2009-04-14 21:07 by java爱好者
总结的不错。

# re: Tomcat 6.0配置数据源(DBCP)和JNDI使用  回复  更多评论   

2009-05-02 11:32 by josdoc
好文章!
Java开源文档(www.josdoc.com)转载了您的文章,
若有异议请告知,谢谢!

# re: Tomcat 6.0配置数据源(DBCP)和JNDI使用[未登录]  回复  更多评论   

2009-12-24 14:38 by sk
第二种方式时:我的还需要把commons-dbcp和commons-pool这两个jar包拷贝到WEB-INF的lib下面.

# re: Tomcat 6.0配置数据源(DBCP)和JNDI使用[未登录]  回复  更多评论   

2010-12-14 01:43 by abc
搜索这么多,只有你的才是对的!非常感谢

# re: Tomcat 6.0配置数据源(DBCP)和JNDI使用  回复  更多评论   

2011-10-08 14:43 by 曹梦
嗯 万分感谢 ,但问下在自己配置的数据源中 factory属性必须添加吗?我这里有一个apps就没有添加factory属性,没有问题。

只有注册用户登录后才能发表评论。


网站导航: