码迷,mamicode.com
首页 > 其他好文 > 详细

JNDI数据源的使用

时间:2017-07-07 22:39:37      阅读:138      评论:0      收藏:0      [点我收藏+]

标签:而且   webapps   文件夹   meta   wait   class   标签   catch   引用   

有时候我们数据库的连接会使用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数据源的使用

标签:而且   webapps   文件夹   meta   wait   class   标签   catch   引用   

原文地址:http://www.cnblogs.com/sharncode/p/7134279.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!