日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JNDI数据源的使用

發布時間:2025/3/15 编程问答 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JNDI数据源的使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

有時候我們數據庫的連接會使用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中進行聲明!

?

轉載于:https://www.cnblogs.com/sharncode/p/7134279.html

總結

以上是生活随笔為你收集整理的JNDI数据源的使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。