`
thinkerAndThinker
  • 浏览: 275986 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

关于Jboss/Tomcat/Jetty的JNDI定义

 
阅读更多
  • Jboss 4

      Jboss中配置JNDI最常见的就是在配置数据源的时候,在server/default/deploy目录下方一个xxx-ds.xml文件,内容如下:

 

[c-sharp] view plaincopyprint?
 
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <datasources>  
  3.   <local-tx-datasource>  
  4.       <jndi-name>jdbc/DataSource</jndi-name>  
  5.       <connection-url>jdbc:jtds:sqlserver://localhost:1433/fnx</connection-url>  
  6.       <driver-class>net.sourceforge.jtds.jdbc.Driver</driver-class>  
  7.       <user-name>sa</user-name>  
  8.       <password>1234</password>  
  9.      <metadata>  
  10.      <type-mapping>MS SQLSERVER2000</type-mapping>  
  11.      </metadata>  
  12.      </local-tx-datasource>  
  13. </datasources>  

 

 

这样我们启动服务器后,在web应用中就可以通过如下代码就可以直接访问到数据源:

 

[c-sharp] view plaincopyprint?
 
  1. Context ctx = new InitialContext();  
  2. Object o=ctx.lookup("java:jdbc/DataSource");  

 

然而这里的java:jdbc/DataSource是一个全局资源名称,Jboss自动将资源加入全局资源,我们经常在应用中看到的java:comp/env/jdbc/DataSource 又是怎么回事?这其实是应用

的私有环境引用名,如果要使用这个引用名称,需要做两件事情(必须做),1、在应用的WEB-INF目录下创建jboss-web.xml,并设置全局到局部引用名得映射

 

[c-sharp] view plaincopyprint?
 
  1. <jboss-web>  
  2.     <resource-ref>  
  3.         <res-ref-name>jdbc/DataSource</res-ref-name>  
  4.         <res-type>javax.sql.DataSource</res-type>  
  5.         <jndi-name>java:/jdbc/DataSource</jndi-name>  
  6.     </resource-ref>     
  7.  <context-root>/</context-root>  
  8. </jboss-web>  

 

2、在web.xml中设置

 

[c-sharp] view plaincopyprint?
 
  1. <web-app>  
  2.   <display-name>Archetype Created Web Application</display-name>  
  3.     
  4.   <resource-ref>  
  5. <description>dataSource</description>  
  6. <res-ref-name>jdbc/DataSource</res-ref-name>  
  7. <res-type>javax.sql.DataSource </res-type>  
  8. <res-auth>Container</res-auth>  
  9.  </resource-ref>   
  10. </web-app>  

 

这样就可以在web应用中使用 java:comp/env/jdbc/DataSource 私有名了。

  • Tomcat 6

 tomcat中配置JNDI有三个地方:

 1、在服务器的Server元素下配置全局的JNDI<GlobalNamingResources>

 2、在host元素的<DefaultContext>中配置,配置后对该host下所有的context应用都有效

 3、在context元素下配置,这里配置的只对该应用有效。

 

需要注意的是,第一种方式配置的全局JNDI,需要在context中使用<ResourceLink>元素转换成局部名才可以使用,功能跟jboss-web.xml中的转换类似。另外,tomcat 中配置的资源不需要在web.xml中进行声明,也可以通过java:comp/env形式进行访问,这一点跟Jboss/jetty有区别。

  上面三个地方可以配置的资源元素是Resource/Environment,ResourceParams是配合Resource使用,而ResourceLink是为了连接转换全局资源。

举个简单例子,在context元素下的配置:(其他的各位自己去看元素如何使用)

 

[c-sharp] view plaincopyprint?
 
  1. <Resource name="mybase" auth="Container"  
  2.             type="org.apache.catalina.UserDatabase"  
  3.             description="User database that can be updated and saved"  
  4.             factory="org.apache.catalina.users.MemoryUserDatabaseFactory"  
  5.             pathname="conf/tomcat-users.xml" />  

 

这样就可以直接在web中使用 java:comp/env/mybase 来查询到资源了。不过还是建议在web.xml中声明一下。

  • Jetty 7

Jetty的JNDI配置也分3个范围

 1、基于JVM全局的,也就是同一个JVM下不同的Server都可以访问

 2、基于Server的,只能在该server下可以访问

 3、基于应用context上下文的,只能在该context下能够访问

配置方式见我上面一篇《JNDI和在JETTY中的运用》

不过这里要注意的是,采用java:comp/env方式访问时,一定要在web.xml中声明资源(除了配置的EnvEntry元素除外,他自动会加入到私有资源),否则你是拿不到资源的。

 

 

  • 总结

可以看到,每个服务器都有他自己的JNDI配置方式和全局访问方式,如果我们直接采用全局访问方式,第一对于一些只对某些应用有关的资源配置可能访问不到,例如JETTY,第二每个

应用服务器的全局访问方式可能不太一致。因此一般建议在应用程序中采用私有方式(java:comp/env)访问资源,并且无论如何都在web.xml中进行申明。这是一个良好的习惯。

 

 

  另外:说到私有环境ENC(java:comp/env),他是如何变成私有的?其实私有是对每个应用上下文来说的,一般每个应用上下文都会用自己的classloader来加载应用,因此利用classloader便可以完成。具体方式是: 用每个应用自己的上下文cloassloader 来初始化一个 JNDI context . 并以 classoader  key 保存起来,以后应用检索时需要使用的应用自己上下文的classloader来查找这个JNDI 资源即可 ,由于其他应用使用不同的classloader实例,也就不能相互共享了,这就是每个应用私有了。另外如果资源命名时采用: java:resourceName, 或者 prefix:resourceName 的方式,虽然我们可以通过java:resourceName, 或者 prefix:resourceName 的方式直接访问,但也注定了这不是私有资源,所有应用都可以访问,需要放到 ENC 下才是私有资源。绑定在 ENC 下访问: java:comp/env/prefix:resourceName

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics