Tomcat 6.0配置数据源(DBCP)和JNDI使用
2010-08-09 15:59
513 查看
Tomcat 6.0 的数据源配置
网上有些资料是5.0方式配置或者解释的不清楚(可能我理解力有问题.呵呵)
给大家我的配置方式:
1,在Tomcat中配置:
tomcat 安装目录下的conf的context.xml 的
<Context></Context>中
添加代码如下:
其中:
name 表示指定的jndi名称
auth 表示认证方式,一般为Container
type 表示数据源床型,使用标准的javax.sql.DataSource
maxActive 表示连接池当中最大的数据库连接
maxIdle 表示最大的空闲连接数
maxWait 当池的数据库连接已经被占用的时候,最大等待时间
username 表示数据库用户名
password 表示数据库用户的密码
driverClassName 表示JDBC DRIVER
url 表示数据库URL地址
示例代码:
测试:
这里并非是在连接类里面写个main()就可以测试成功的,如果这样会出现下面的错误:
javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial
at javax.naming.spi.NamingManager.getInitialContext(Unknown Source)
at javax.naming.InitialContext.getDefaultInitCtx(Unknown Source)
at javax.naming.InitialContext.getURLOrDefaultInitCtx(Unknown Source)
at javax.naming.InitialContext.lookup(Unknown Source)
at util.DBConnection.getConnection(DBConnection.java:26)
at util.DBConnection.main(DBConnection.java:49)
所以,只有通过和前台结合才能测试连接是否成功。
总结:
context.xml必须在项目的WebRoot/META-INF,Tomcat会自动找这个文件;
数据库驱动包必须放在Tomcat的lib目录下(可能是Tomcat会根据context.xml在自身的lib目录下找驱动包);
不可以直接在连接类中写main()测试,必须和前台结合;
[/code] 同时你需要把你使用的数据驱动jar包放到Tomcat的lib目录下。
网上有些资料是5.0方式配置或者解释的不清楚(可能我理解力有问题.呵呵)
给大家我的配置方式:
1,在Tomcat中配置:
tomcat 安装目录下的conf的context.xml 的
<Context></Context>中
添加代码如下:
<Resource name="jdbc/liuwei" auth="Container" type="javax.sql.DataSource" maxActive="20" maxIdel="10" maxWait="1000" username="sa" password="12345678" driverClassName="net.sourceforge.jtds.jdbc.Driver" url="jdbc:jtds:sqlserver://127.0.0.1:1433;DatabaseName=andy"> </Resource>
其中:
name 表示指定的jndi名称
auth 表示认证方式,一般为Container
type 表示数据源床型,使用标准的javax.sql.DataSource
maxActive 表示连接池当中最大的数据库连接
maxIdle 表示最大的空闲连接数
maxWait 当池的数据库连接已经被占用的时候,最大等待时间
username 表示数据库用户名
password 表示数据库用户的密码
driverClassName 表示JDBC DRIVER
url 表示数据库URL地址
示例代码:
连接类: public class DBConnection { private Connection conn=null; public Connection getConnection(){ //生成上下文对象,通过它可以向容器发送别名. Context context; try { context = new InitialContext(); //查找对象 DataSource ds=(DataSource)context.lookup("java:comp/env/jdbc/liuwei");//jdbc/liuwei为配置文件中的name //得到连接 try { conn=ds.getConnection(); } catch (SQLException e) { e.printStackTrace(); } } catch (NamingException e) { // TODO Auto-generated catch block e.printStackTrace(); } return conn; } 如果你使用其他数据源如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,你应该把
[code] factory="org.apache.commons.dbcp.BasicDataSourceFactory" 改为
factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"
测试:
这里并非是在连接类里面写个main()就可以测试成功的,如果这样会出现下面的错误:
javax.naming.NoInitialContextException: Need to specify class name in environment or system property, or as an applet parameter, or in an application resource file: java.naming.factory.initial
at javax.naming.spi.NamingManager.getInitialContext(Unknown Source)
at javax.naming.InitialContext.getDefaultInitCtx(Unknown Source)
at javax.naming.InitialContext.getURLOrDefaultInitCtx(Unknown Source)
at javax.naming.InitialContext.lookup(Unknown Source)
at util.DBConnection.getConnection(DBConnection.java:26)
at util.DBConnection.main(DBConnection.java:49)
所以,只有通过和前台结合才能测试连接是否成功。
总结:
context.xml必须在项目的WebRoot/META-INF,Tomcat会自动找这个文件;
数据库驱动包必须放在Tomcat的lib目录下(可能是Tomcat会根据context.xml在自身的lib目录下找驱动包);
不可以直接在连接类中写main()测试,必须和前台结合;
[/code] 同时你需要把你使用的数据驱动jar包放到Tomcat的lib目录下。
相关文章推荐
- Tomcat 6.0配置数据源(DBCP)和JNDI使用
- Tomcat 6.0配置数据源(DBCP)和JNDI使用
- Tomcat 6.0配置数据源(DBCP)和JNDI使用
- Tomcat 配置数据源(DBCP)和JNDI使用
- JNDI和在tomcat中配置DBCP连接池 元数据的使用 DBUtils框架的使用 多表操作
- WEB项目中,让FineReport6.5使用Tomcat下所配置的JNDI数据源
- tomcat6.0中配置JNDI的DBCP连接及JNDI在程序中调用
- JNDI学习总结(三)——Tomcat下使用Druid配置JNDI数据源
- Tomcat6.0 配置外部数据源(JNDI)
- Tomcat下使用Druid配置JNDI数据源
- JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源
- tomcat中通过JNDI数据源配置使用
- tomcat6.0中配置JNDI的DBCP连接及maxIdle ,MaxActive,maxWait介绍
- 什么是jndi,什么时候使用jndi,tomcat配置jndi,spring使用jndi数据源
- JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源
- JNDI学习总结(二)——Tomcat下使用C3P0配置JNDI数据源
- 使用 JNDI 在 Tomcat 的 server.xml 中配置 Druid 数据源
- JNDI学习总结(三)——Tomcat下使用Druid配置JNDI数据源
- Tomcat6.0 配置外部数据源(JNDI)