`
JustOnly
  • 浏览: 6356 次
  • 性别: Icon_minigender_1
  • 来自: 火星
最近访客 更多访客>>
社区版块
存档分类
最新评论

Tomcat 的数据源使用(1)

阅读更多
一、数据源简介

  在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></resource>,在web.xml加入<resource-ref></resource-ref>元素,声明该Web应用所引用的数据。

  A.在server.xml中加入<resource></resource>元素:<resource></resource>元素用来定义JNDI Resource。
  
  属性    描述
  name    指定Resource的JNDI名字
  auth    指定管理Resource的Manager,它有两个可选值:Container、Application
  type    指定Resource所属的Java类名

 

<!----><Resource name = "jdbc/BookDb"  auth = "Container"     type = "javax.sql.DataSource" />

  B.在<resource></resource>元素中加入<resourceparams></resourceparams>元素:<resourceparams></resourceparams>元素用来指定各种参数值
  
  属性      描述
  factory    指定生成的DataResource的factory类名
  maxActive    指定数据库连接池中处于活动状态的最大连接数目,0表示不受限制
  maxIdle    指定数据库连接池中处于空闲状态的最大连接数目,0表示不受限制
  maxWait    指定连接池中连接处于空闲状态的最长时间,超过会抛出异常,-1表示无限
  username    指定连接数据库的用户名
  password    指定连接数据库的口令
  driverClassName    指定连接数据库的JDBC驱动程序
  url  指定连接数据库的URL

<!----><ResourceParams name = "jdbc/BookDb"> <parameter> <name>factoryname> <value>org.apache.commons.dbcp.BasicDataSourceFactoryvalue> parameter> <parameter> <name>maxActivename> <value>100value> parameter> <parameter> <name>maxIdlename> <value>30value> parameter> <parameter> <name>maxWaitname> <value>10000value> parameter> <parameter> <name>usernamename> <value>uservalue> parameter> <parameter> <name>passwordname> <value>1234value> parameter> <parameter> <name>driverClassNamename> <value>com.mysql.jdbc.Drivervalue> parameter> <parameter> <name>urlname> <value>jdbc:mysql//localhost:3306/BookDb?autoReconnect=true parameter> ResourceParams>

 

  C.在web.xml中加入<resource-ref></resource-ref>元素:<resource-ref></resource-ref>元素表示在Web应用中引用JNDI资源
  
  属性      描述
  description    对所引用的资源的说明
  res-ref-name    指定所引用资源的JNDI名字,与<resource></resource>元素中的name属性对应
  res-type  指定所引用资源的类名字,与<resource></resource>元素中的type属性对应
  res-auth  指定所引用资源的Manager,与<resource></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中应用JNDI访问数据源
--java:comp/env是TOMCAT 固定的,Tomcat提供的JNDI绑定都必须加此前缀,
--jdbc/dstest 是定义数据源时的数据名
 final String JNDINAME ="java:comp/env/jdbc/dstest";
 Context  ctx = new InitalContext();
 DataSource ds = (DataSource)ctx.lookup(JNDINAME);
 Connection conn = ds.getConnection();
 Statement stmt=conn.createrStatement();
 ResultSet rs = stmt.executeQuery( "sql 语句");
 while(rs.next)
 {}
---------
可通过修改server.xml文件来进行配置全局数据源,配置方式与局部数据源类似,只是修改的文件不同.
局部数据源只需要修改web应用的配置文件,而全局数据源需要修改Tomcat的系统文件.
一般尽量不使用全局数据源.

相关推荐

    tomcat数据源JAR

    标题中的“tomcat数据源JAR”指的是在Apache Tomcat服务器中用于管理数据库连接的数据源配置和相关的库文件。在Java应用服务器中,数据源(DataSource)是用于存储数据库连接的池,它允许应用程序高效地获取和释放...

    配置Tomcat数据源

    配置Tomcat数据源的知识点主要包括以下几个方面: 1. 数据源(DataSource)的概念: 数据源是数据库连接池的一种实现,它允许应用程序从池中获取数据库连接。数据库连接池的作用是预先建立一定数量的数据库连接,并...

    配置tomcat数据源

    【标题】"配置Tomcat数据源"涉及到的是在Apache Tomcat服务器中设置应用程序的数据连接池,以便应用程序可以高效、安全地访问数据库。Tomcat作为一款流行的开源Java Servlet容器,经常被用于部署Java Web应用程序。...

    Tomcat 数据源配置

    #### 一、理解Tomcat数据源配置的重要性 在现代Web应用开发中,数据库作为数据持久层的重要组成部分,其性能和稳定性直接影响到整个应用程序的表现。因此,合理配置数据库连接池(即数据源)对于提高Web应用的响应...

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

    在这个场景中,“intellij idea使用tomcat开发时自动部署jndi数据源”是一个重要的知识点,它涉及到如何在IDE中配置和管理数据库连接,以便于在应用运行时动态地查找和使用数据源。 JNDI(Java Naming and ...

    tomcat数据源连接池配置

    在Java Web应用中,Tomcat作为一款广泛应用的Servlet容器,其数据源连接池配置是确保高效、稳定数据库访问的关键步骤。本篇文章将详细介绍如何在Tomcat中配置数据源连接池,以及涉及的相关jar包文件。 首先,理解...

    TomCat数据源配置

    总结,配置Tomcat数据源是Java Web应用中非常关键的步骤,它涉及到服务器与数据库之间的通信,合理的配置可以提升系统性能并降低资源消耗。在Tomcat 5.5中,我们通过修改`server.xml`文件来定义数据源,并在JSP页面...

    Tomcat JDNI数据源配置详解

    在Tomcat环境下使用JNDI配置数据源,首先需要在`server.xml`文件中定义数据源。具体步骤如下: 1. **打开配置文件**:找到Tomcat安装目录下的`conf/server.xml`文件。 2. **添加数据源定义**:在`&lt;Host&gt;`标签内添加...

    tomcat数据源的配置及使用

    tomcat数据源的配置及使用 在eclipse中开发的示例,txt文档的说明,exe文件的教程。在使用JNDI,可分为5步 (1)配置context.xml文件(Tomcat 6.0\conf文件夹下),把连接数据库用的驱动包(sqljdbc.jar)复制到...

    tomcat配置数据源

    在给定的部分内容中,我们可以看到一个具体的Tomcat数据源配置示例。下面将详细解释这些配置项的具体含义及其作用: 1. **定义上下文路径**: ```xml ``` 这行代码指定了Web应用的上下文路径为“/JSP”,同时...

    tomcat数据源oralce模板配置

    在Java Web应用中,Tomcat作为一款广泛应用的Servlet容器,经常需要配置数据源来连接数据库。本篇将详细讲解如何在Tomcat中配置Oracle数据源的模板,这将为其他数据库的配置提供参考。 首先,我们需要了解数据源...

    tomcat8 JNDI数据源加密

    TOMCAT8 JNDI对用户名和密码加密

    tomcat jboss数据源配置.rar

    通过上述配置,Tomcat和JBoss就能识别并使用Oracle数据源了。在实际应用中,可能还需要考虑其他的配置参数,如连接超时、验证查询、公平获取策略等,以优化数据库连接池的性能和稳定性。 总之,配置Tomcat和JBoss的...

    Tomcat数据源配置

    配置Tomcat数据源主要涉及以下几个步骤: 1. **创建配置文件**:在Tomcat的`conf`目录下,创建或修改`context.xml`文件。此文件用于定义全局数据源,所有部署在Tomcat上的Web应用都可以共享这个数据源。 2. **定义...

    tomcat下配置数据源附xml文件

    配置Tomcat数据源分为以下几个步骤: 1. **创建JDBC驱动类的JAR文件**:确保你的Tomcat安装目录下的`lib`目录包含了对应数据库的JDBC驱动JAR文件。例如,如果是MySQL,你需要`mysql-connector-java.jar`。 2. **...

    tomcat配置数据源步骤

    1. **理解数据源与连接池** 数据源是Java中的一个接口,通常由JNDI(Java Naming and Directory Interface)服务管理,它提供了一种统一的方式来获取和释放数据库连接。连接池则是在应用程序启动时预先创建并管理一...

    DbUtil和tomcat数据源配置实例

    在Java Web开发中,数据库连接管理是一个至关重要的环节。`DbUtil`是一个常见的数据库操作工具类,用于简化数据库连接的创建、关闭等操作,而...通过实际操作,你可以更好地掌握`DbUtil`和Tomcat数据源的配置与使用。

    数据源使用代码tomcat + jsp

    ### 数据源配置与使用:Tomcat + JSP #### 一、引言 在Web开发中,数据库连接是一项非常重要的工作。为了确保应用程序能够高效稳定地访问数据库资源,合理配置数据源是必不可少的一环。本篇文章将详细介绍如何在...

    详细介绍在tomcat中配置数据源原理

    Tomcat 中配置数据源原理详解 在本文中,我们将详细介绍在 Tomcat 中配置数据源的原理。数据源是指Java应用程序连接数据库的接口,通过配置数据源,我们可以在 Java 应用程序中访问数据库。 首先, let's talk ...

    Tomcat数据源

    【描述】"MLDN课程--tomcat数据源"可能是一个教学视频,详细讲解了如何在Tomcat环境中设置和使用数据源。该课程可能涵盖了以下几个关键点: 1. **JNDI(Java Naming and Directory Interface)**:在Java EE环境中...

Global site tag (gtag.js) - Google Analytics