`
zhangsibei
  • 浏览: 15612 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

tomcat 中JNDI的使用

阅读更多
一、数据源简介:
    在Java语言中,DataSource对象就是一个代表数据源实体的对象。一个数据源就是一个用来存储数据的工具,它可以是复杂的大型企业级数据库,也可以是简单得只有行和列的文件。数据源可以位于在服务器端,也可以位于客服端。应用程序通过一个连接来访问数据源,那么一个DataSource对象就是用于提供连接数据源的工具。DataSource接口提供了两个方法用于建立和数据源的连接使用DataSource对象建立和数据库的连接比起使用 DriverManager接口更加高效,虽然两者的使用范围都很相似,并且都提供了方法用于建立和数据库的连接,设置连接的最大超时时间,获取流、登录。但两者之间的区别更加明显。和DriverManager不同,一个DataSource对象能够识别和描述它所代表的数据源的属性,而且 DataSource对象的工作和JNDI(Javatm Naming and Directory Interfaceti)具有密切的关系,DataSource的建立、发布、独立于应用程序的管理都依靠JNDI技术。在JDBC2.0或 JDBC3.0中,所有的数据库驱动程序提供商必须提供一个实现了DataSource接口的类,要使用数据源必须首先在JNDI中注册该数据源对象。如果在JNDI中注册了数据源对象,将会比起使用DriverManager来具有两个方面的优势:首先程序不需要像使用DriverManager一样对加载的数据库驱动程序信息进行硬编码,程序员可以选择先在JNDI中注册这个数据源对象,然后在程序中使用一个逻辑名称来引用它,JNDI会自动根据你给出的名称找到与这个名称绑定的DataSource对象。然后就可以使用这个DataSource对象来建立和具体数据库的连接了。其次,使用实现了 DataSource接口的类所具有的第二个优势体现在连接池和分布式事务上。连接池通过对连接的复用而不是新建一个物理连接来显著地提高程序的效率。从而适用于任务繁忙、负担繁重的企业级分布式事务。
二、JNDI简介:
    JNDI是用于向Java程序提供目录和命名功能的API。它被设计成独立于特定的目录服务,所以各种各样的目录都可以通过相同的方式进行访问。可以简单地把JNDI理解为一种将对象和名字绑定的技术,对象工厂负责生产出对象,这些对象都和惟一的名字绑定。外部程序可以通过名字来获取对某个对象的引用。在 Intranets(企业内部网)和Internates(互联网)中目录服务(Directory service)扮演了一个非常重要的角色,它能够在众多的用户、机器、网络、服务、应用程序中访问各种各样的信息。目录服务提供了一系列的命名措施,用人类可以理解的命名方式来刻画各种各样的实体之间的关系一个企业式计算环境(computing environment)通常是由若干代表不同部分的命名复合而成。比如在一个企业级环境中DNS(Domain Name System)通常被当成顶层的命名方案(top-level namein facility)区分不同的部门或组织。而这些部门或组织自己又可以使用诸如LADP或NDS的目录服务从用户的角度来看,这些都是由不同的命名方案构成的复合名称。URL就是一个很典型的例子,它由多个命名方案构成。使用目录服务的应用程序必须支持这种复合构成方式使用目录服务API的Java开发人员获得的好处不仅在于API独立于特定的目录或命名服务,而且可以通过多层的命名方案无缝访问(seamless acess)目录对象。实际上,任何的应用程序都可以将自身的对象和特定的命名绑定起来,这种功能可以使到任何的Java程序查找和获取任何类型的对象终端用户可以方便地使用逻辑名称从而轻易地在网络上查找和识别各种不同的对象,目录服务的开发人员可以使用API方便地在不同的客服端之间切换而不需要作任何更改
三、数据源和连接池的关系:
***********************************************************************************
JDBC2.0 提供了javax.sql.DataSource接口,它负责建立与数据库的连接,在应用程序访问数据库时不需要编写连接数据库的代码,可以直接从数据源获得数据库连接。 在DataSource中事先建立了多个数据库连接,这些数据库连接保存在连接池(Connect Pool)中。Java程序访问数据库时,只需要从连接池中取出空闲状态的数据库连接;当程序访问数据库结束,再将数据库连接放回连接池。
***********************************************************************************
四、数据源和JNDI的关系:
***********************************************************************************
DataSource 对象是由Tomcat提供的,因此不能在程序中采用创建一个实例的方式来生产DataSource对象,而需要采用Java的另一个技术JNDI,来获得 DataSource对象的引用。Tomcat把DataSource作为一种可以配置的JNDI资源来处理。生成DataSource对象的工厂为 org.apache.commons.dbcp.BasicDataSourceFactory。在javax.naming包中提供了Context 接口,该接口提供了将对象和名字绑定,以及通过名字检索对象的方法。Context中的主要方法有:bind(String name,Object object):将对象与一个名字绑定lookup(String name):返回与指定的名字绑定的对象
***********************************************************************************
五、Tomcat中数据源的配置:
***********************************************************************************
数据源的配置涉及修改server.xml和web.xml,在server.xml中加入定义数据源的元素<resource>,在 web.xml加入<resource-ref>元素,声明该Web应用所引用的数据A.在server.xml中加入<resource>元素:<resource>元素用来定义JNDI Resource。  属性 描述name 指定Resource的JNDI名字auth 指定管理Resource的Manager,它有两个可选值:Container、Applicationtype 指定Resource所属的Java类名<resource name = "jdbc/BookDb" auth = "Container" type = "javax.sql.DataSource">B.在<resource>元素中加入<resourceparams> 元素:<resourceparams>元素用来指定各种参数值  属性 描述factory 指定生成的DataResource的factory类名maxActive 指定数据库连接池中处于活动状态的最大连接数目,0表示不受限制maxIdle 指定数据库连接池中处于空闲状态的最大连接数目,0表示不受限制maxWait 指定连接池中连接处于空闲状态的最长时间,超过会抛出异常,-1表示无限username 指定连接数据库的用户名password 指定连接数据库的口令driverClassName 指定连接数据库的JDBC驱动程序url 指定连接数据库的URL<resourceparams name = "jdbc/BookDb"><parameter><name>factory</name><value>org.apache.commons.dbcp.BasicDataSourceFactory</value></parameter><parameter><name>maxActive</name><value>100</value></parameter><parameter><name>maxIdle</name><value>30</value></parameter><parameter><name>maxWait</name><value>10000</value></parameter><parameter><name>username</name><value>user</value></parameter><parameter><name>password</name><value>1234</value></parameter> <parameter><name>driverClassName</name><value>com.mysql.jdbc.Driver</value></parameter><parameter><name>url</name><value>jdbc:mysql//localhost:3306/BookDb?autoReconnect=true</value></parameter> </resourceparams>C.在web.xml中加入<resource-ref>元素:<resource- ref>元素表示在Web应用中引用JNDI资源  属性 描述description 对所引用的资源的说明res-ref-name 指定所引用资源的JNDI名字,与<resource>元素中的name属性对应res-type 指定所引用资源的类名字,与<resource>元素中的type属性对应res-auth 指定所引用资源的Manager,与<resource>元素中的auth属性对应
***********************************************************************************
六、在Web应用中使用数据源:
***********************************************************************************
javax.naming.Context 提供了查找JNDI Resource的接口,可以通过三个步骤来使用数据源对象:A.获得对数据源的引用:    Context ctx = new InitalContext();DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/BookDb");B.获得数据库连接对象:Connection con = ds.getConnection();  C.返回数据库连接到连接池:con.close();在连接池中使用close()方法和在非连接池中使用 close()方法的区别是:前者仅仅是把数据库连接对象返回到数据库连接池中,是连接对象又恢复到空闲状态,而非关闭数据库连接,而后者将直接关闭和数据库的连接
***********************************************************************************
七、发布使用数据源的Web应用:
***********************************************************************************
  如果直接同JDBC访问数据库,可以把JDBC驱动程序拷贝到Web应用的WEB-INF/lib目录或者Tomcat安装目录下的common /lib目录下。    如果通过数据源访问数据库,由于数据源由Servlet容器创建并维护,所以必须把JDBC驱动程序拷贝到Tomcat安装目录下的common/lib目录下,确保Servlet容器能够访问驱动程序。

***********************************************************************************
八、Web应用的例子:
***********************************************************************************

数据源的配置也可以在自己的web项目中配置,这样可以为每个web项目配置不同的数据源。

1 配置数据源:
建立 %TOMCAT_HOME%\webapps\yourApp\META-INF\context.xml 文件。
这个这个文件也可以在用<a href="http://localhost:8080/admin/">http://localhost:8080/admin/< /a>登录后,在目录的 Service/Host(localhost)/Context(/yourApp)/Resources/Data Sources下做数据源配置时自动生成。

2 引用数据源:
在 %TOMCAT_HOME%\webapps\yourApp\WEB-INF\web.xml 文件中加入对配好的数据源的引用。

3 加入JDBC驱动:
将JDBC驱动放在 %TOMCAT_HOME%\common\lib 和 %TOMCAT_HOME%\webapps\yourApp\WEB-INF\lib 目录下。

4 在JSP页面中应用数据源:
建立 %TOMCAT_HOME%\webapps\yourApp\yourpage.jsp 文件。

****一个例子*****

context.xml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<context>
<resource auth="Container" name="jdbc/sqlsvr" type="javax.sql.DataSource" password="db2admin" driverclassname="net.sourceforge.jtds.jdbc.Driver" maxidle="2" maxwait="5000" username="db2admin" url="jdbc:jtds:sqlserver://crm_server:1433/Sinochem" maxactive="4">
</context>

web.xml 文件:(仅数据源引用部分)
<resource-ref> 
<description>Sql Server Datasource</description> 
<res-ref-name>jdbc/sqlsvr</res-ref-name> 
<res-type>javax.sql.DataSource</res-type> 
<res-auth>Container</res-auth>
</resource-ref>
分享到:
评论

相关推荐

    Tomcat中JNDI原理

    Tomcat通过`org.apache.naming.ContextBindings`类实现了JNDI中的`ContextBinding`机制。`ContextBindings`类负责维护一个`java.util.Hashtable`,用于存储和管理ClassLoader级别的上下文绑定信息。这允许每个应用或...

    tomcat8 JNDI数据源加密

    TOMCAT8 JNDI对用户名和密码加密

    tomcat-jndi

    在Java应用服务器中,Tomcat是一个广泛使用的轻量级服务器,而JNDI(Java Naming and Directory Interface)则是Java平台中的一个核心API,用于提供命名和目录服务。本篇文章将深入探讨Tomcat与JNDI的结合使用,帮助...

    tomcat配置jndi数据源

    Tomcat 中的 JNDI 数据源是指将数据库连接信息注册到 JNDI 服务器中,以便在应用程序中可以通过 JNDI 名称来获取数据库连接。下面我们将详细介绍 Tomcat 配置 JNDI 数据源的多种方式。 方式一:配置单个应用数据源 ...

    intellij idea使用tomcat开发时自动部署jndi数据源

    通过以上步骤,开发者可以在IntelliJ IDEA中使用Tomcat自动部署JNDI数据源,实现高效、灵活的数据库连接管理。这对于大型企业级应用来说尤其重要,因为它简化了数据库连接的配置和管理,使得团队协作变得更加顺畅。

    Tomcat6.0 JNDI数据源经典实例

    本实例是一个关于如何在Tomcat 6.0中配置和使用JNDI数据源的经典示例,包含了所需的JAR包、配置文件和SQL脚本。 首先,我们来看配置JNDI数据源的步骤。在Tomcat的`conf/server.xml`文件中,你需要添加一个新的`...

    (收集)tomcat jndi

    在Java应用服务器中,Tomcat是一个广泛使用的轻量级服务器,它支持各种Java企业级规范,包括Java Naming and Directory Interface (JNDI)。JNDI是一个Java API,允许应用程序查找和访问不同类型的命名和目录服务,如...

    eclipse+mysql+tomcat配置JNDI

    在Tomcat中,JNDI常用于配置数据库连接池,使得多个Web应用可以共享同一个数据库连接。 配置JNDI的步骤如下: 1. **安装与配置MySQL**: 首先确保你已经安装了MySQL数据库,并创建了所需的数据库和用户。你需要...

    Tomcat配置JNDI数据源的N种方法

    Tomcat配置JNDI数据源的N种方法

    tomcat配置JNDI数据源

    【标题】:“Tomcat配置JNDI数据源” 【描述】:“在Tomcat服务器上配置JNDI数据源,特别是通过DBCP连接池的方式” 【标签】:“tomcat,配置,JNDI数据源” 【内容】:配置JNDI数据源在Java Web应用程序中是一个...

    在Tomcat配置JNDI数据源的三种方式

    在Tomcat配置JNDI数据源的三种方式

    tomcat6中配置JNDI方法

    ### Tomcat6中配置JNDI方法详解 #### 一、引言 在Java Web开发过程中,连接数据库是一项基础而重要的工作。常见的连接方式包括直接使用JDBC(Java Database Connectivity)以及通过JNDI(Java Naming and Directory...

    Tomcat通过JNDI方式连接SqlServer数据库

    在配置完成后,我们可以在WEB应用程序中使用JNDI来访问数据库。我们需要在WEB-INF目录下创建一个web.xml文件,以指定JNDI数据源。然后,我们可以在JSP页面中使用JNDI来连接数据库。 在本文中,我们将详细介绍如何...

    tomcat配置jndi

    总结,配置Tomcat中的JNDI主要是为了方便和高效地管理数据库连接,通过在服务器端定义数据源,并在应用程序中通过JNDI查找和使用,可以极大地简化开发工作。理解并掌握这一过程对于任何使用Tomcat部署Java Web应用的...

    tomcat jndi数据源解密factory

    自定义jndi数据源factory类,用于解密jndi中的加密数据,解密方式为DES,具体可根据实际需求修改。

    tomcat6.0 配置jndi

    在Tomcat6.0中配置JNDI,主要是为了实现应用中的数据源管理,使得多个应用可以共享一个数据库连接池,提高资源利用率和系统性能。 **一、JNDI的基本概念** JNDI提供了一个统一的接口,让开发者可以查找和绑定各种...

    Tomcat6配置JNDI出错

    4. **Web应用上下文配置**:如果你的应用是在特定的Web应用上下文中使用JNDI,那么需要在该应用的`WEB-INF/web.xml`中进行额外的上下文初始化参数配置。 5. **权限问题**:配置的JNDI资源需要适当的权限才能被应用...

    TOMCAT7 JNDI修正版

    数据源可以不用写java:comp了,直接写ID和WEBLOGIC一样 数据源可以不用写java:comp了,直接写ID和WEBLOGIC一样数据源可以不用写java:comp了,直接写ID和WEBLOGIC一样

    Tomcat JNDI配置

    Tomcat JNDI 配置是 Java Web 应用程序中的一种常见配置,用于将数据库连接信息以 JNDI(Java Naming and Directory Interface)的形式存储在 Tomcat 服务器中,以便于应用程序可以通过 JNDI 来获取数据库连接信息。...

Global site tag (gtag.js) - Google Analytics