Tomcat 6.0配置數(shù)據(jù)源(DBCP)和JNDI使用
Posted on 2009-04-14 17:10 ytl 閱讀(8090) 評(píng)論(6) 編輯 收藏 所屬分類(lèi): 學(xué)習(xí)總結(jié)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平臺(tái)企業(yè)級(jí)開(kāi)發(fā)的分布式計(jì)算環(huán)境以組織和查找組件方式與其他技術(shù)協(xié)同工作。
Tomcat 6.0 的數(shù)據(jù)源配置
給大家我的配置方式:
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名稱(chēng)
auth 表示認(rèn)證方式,一般為Container
type 表示數(shù)據(jù)源床型,使用標(biāo)準(zhǔn)的javax.sql.DataSource
maxActive 表示連接池當(dāng)中最大的數(shù)據(jù)庫(kù)連接
maxIdle 表示最大的空閑連接數(shù)
maxWait 當(dāng)池的數(shù)據(jù)庫(kù)連接已經(jīng)被占用的時(shí)候,最大等待時(shí)間
username 表示數(shù)據(jù)庫(kù)用戶(hù)名
password 表示數(shù)據(jù)庫(kù)用戶(hù)的密碼
driverClassName 表示JDBC DRIVER
url 表示數(shù)據(jù)庫(kù)URL地址
同時(shí)你需要把你使用的數(shù)據(jù)驅(qū)動(dòng)jar包放到Tomcat的lib目錄下。
如果你使用其他數(shù)據(jù)源如DBCP數(shù)據(jù)源,需要在<Resouce 標(biāo)簽多添加一個(gè)屬性如
factory="org.apache.commons.dbcp.BasicDataSourceFactory"
當(dāng)然你也要把DBCP相關(guān)jar包放在tomcat的lib目錄下。
這樣的好處是,以后的項(xiàng)目需要這些jar包,可以共享適合于項(xiàng)目實(shí)施階段。
如果是個(gè)人開(kāi)發(fā)階段一個(gè)tomcat下部署多個(gè)項(xiàng)目,在啟動(dòng)時(shí)消耗時(shí)間,同時(shí)
可能不同項(xiàng)目用到不用數(shù)據(jù)源帶來(lái)麻煩。所以有配置方法2
2在項(xiàng)目的中配置:
2.1 使用自己的DBCP數(shù)據(jù)源
在WebRoot下面建文件夾META-INF,里面建一個(gè)文件context.xml,
添加內(nèi)容和 配置1一樣
同時(shí)加上<Resouce 標(biāo)簽多添加一個(gè)屬性如
factory="org.apache.commons.dbcp.BasicDataSourceFactory"
這樣做的:可以把配置需要jar包直接放在WEB-INF的lib里面 和web容器(Tomcat)無(wú)關(guān)
總后一點(diǎn):提醒大家,有個(gè)同學(xué)可能說(shuō) tomacat的有DBCP的jar包,確實(shí)tomcat把它放了
進(jìn)去,你就認(rèn)為不用添加DBCP數(shù)據(jù)源的jar包,也按照上面的配置,100%你要出錯(cuò)。
因?yàn)閠omcat重新打包了相應(yīng)的jar,你應(yīng)該把
factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory" 改為
factory="org.apache.commons.dbcp.BasicDataSourceFactory"
同時(shí)加上DBCP 所依賴(lài)的jar包(commons-dbcp.jar和commons-pool.jar)
你可以到www.apache.org 項(xiàng)目的commons里面找到相關(guān)的內(nèi)容
2.2 使用Tomcat 自帶的DBCP數(shù)據(jù)源
在WebRoot下面建文件夾META-INF,里面建一個(gè)文件context.xml,
添加相應(yīng)的內(nèi)容
這是可以不需要添加配置
配置1一樣
factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"
也不要想添加額外的jar包
最后,不管使用哪種配置,都需要把數(shù)據(jù)庫(kù)驅(qū)動(dòng)jar包放在目錄tomcat /lib里面
JNDI使用示例代碼:



















謝謝!