1. 程式人生 > >JNDI數據源的使用

JNDI數據源的使用

webapps 三種 web 配置 斜杠 pri 沒有 onf 通過

有時候我們數據庫的連接會使用jndi的方式

try
        {
            InitialContext ic = new InitialContext();
            dataSource = (DataSource) ic.lookup("java:/comp/env/jdbc/murach");
        }
        catch(Exception e)
        {
            e.printStackTrace();
        }

各種不同的J2EE容器,都用不同的配置方式。
tomcat可以配置全局JNDI和私有JNDI(註意這裏說的Tomcat6):

!!!首先想要說明的是Tomcat的配置不需要修改web.xml裏面的任何內容!!!
!!!Tomcat的全局JNDI資源不能直接訪問,必須有java:comp/env/前綴!!!

全局的JNDI配置在server.xml裏面的標簽裏面添加如下配置:

<Resource name="jdbc/murach"
auth="Container" 
type="javax.sql.DataSource" 
driverClassName="com.mysql.jdbc.Driver" 
url="jdbc:mysql://127.0.0.1/test" 
username="root" 
password
="root" maxActive="20" maxIdle="10" maxWait="-1"/>

然後某一個項目想要引用這個全局的JNDI,就需要在項目的META-INF下面建立context.xml文件,在裏面寫上:

<?xml version="1.0" encoding="UTF-8"?> 
<Context> 
<ResourceLink name="jdbc/test" global="jdbc/murach" type="javax.sql.DataSource"/> 
</Context>

這樣就可以在程序裏面通過context.lookup(“java:comp/env/jdbc/murach”)進行訪問了。

私有的JNDI有三種方式可以配置:
1、可以直接在server.xml裏面的節點下添加如下配置:

<Context path="/test_tomcat6_jndi"> 
<Resource name="jdbc/test" 
auth="Container" 
type="javax.sql.DataSource" 
driverClassName="com.mysql.jdbc.Driver" 
url="jdbc:mysql://127.0.0.1/test" 
username="root" 
password="root" 
maxActive="20" 
maxIdle="10" 
maxWait="-1"/> 
</Context> 


這樣就可以直接在程序中通過context.lookup(“java:comp/env/jdbc/test”)訪問了,需要註意的是path=”/test_tomcat6_jndi”,這個名字必須和你的項目名稱相同,而且不能少了那個斜杠,而且你的項目是通過拷貝文件夾到webapps下面的方式進行的部署。

2、 也可以在conf/context.xml裏面增加如下配置:

<Resource name="jdbc/test" 
auth="Container" 
type="javax.sql.DataSource" 
driverClassName="com.mysql.jdbc.Driver" 
url="jdbc:mysql://127.0.0.1/test" 
username="root" 
password="root" 
maxActive="20" 
maxIdle="10" 
maxWait="-1"/> 

這樣就可以直接在程序中通過context.lookup(“java:comp/env/jdbc/test”)訪問了

3、還可以在項目的WebRoot下面的META-INF文件夾下面創建context.xml文件,再在context.xml文件裏面寫上

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

這樣就可以直接在程序中通過context.lookup(“java:comp/env/jdbc/test”)訪問了

你可以發現的是:以上的Tomcat6中的配置不管是全局還是局部,都沒有修改項目的web.xml文件,但是仍然建議在web.xml中進行引用,主要是為了項目的遷移,因為有的服務器需要在web.xml中進行聲明!

JNDI數據源的使用