`
kobe学java
  • 浏览: 258049 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

Tomcat中详细配置数据源及其原理解析

 
阅读更多

Tomcat中数据源的配置及原理
一:数据源介绍
数据源JDBC2.0提供了javax.sql.DataSource的接口,负责与数据库建立连接,实际应用时不需要编写连接数据库代码,可以直接从数据源获得数据库的连接,使得应用于数据库的耦合降低。Dataource中事先建立了多个数据库连接,这些数据库连接保持在数据库连接池中,当程序访问数据库时,只需要从连接池从取出空闲的连接,访问数据库结束,在将这些连接归还给连接池。DataSource对象由容器(Tomcat)提供,不能使用创建实例的方法来生成DataSource对象,要采用JAVA的JNDI(Java Nameing and Directory Interface,java命名和目录接口)来获得DataSource对象的引用。(另有一种说法:“其实从技术上来说,数据源连接方式是不需要目录服务的,我们同样可以通过序列化数据源对象直接访问文件系统。这点是需要明确的。”感兴趣的朋友可以试试。)JNDI是一种将对象和名字绑定的技术,对象工厂负责生产出对象,这些对象都和唯一的名字相绑定。程序中可以通过这个名字来获得对象的引用。Tomcat把DataSource作为一种可配置的JNDI资源来处理,生成DataSource对象的工厂为org.apache.comm.ons.dbcp.BasicDataSourceFactory。
二:配置数据源
在Tomcat中配置数据源其相当简单,可以配置单个应用的数据源,也可以配置整个容器的数据源。以下详细说明如何配置单个应用的数据源。
1.准备工作
  • Tomcat4.1.24 (其它版本也可以,原理相通的)
  •   确认在%Tomcat _Home%/common/lib下有commons-collections.jar、commons-dbcp.jar、commons-pool.jar包(tomcat默认有这些包),如果没有,请到此地下载:http://tomcat.apache.org/ 。这三个包是必需的。
  • 下载相应数据库驱动,放在%Tomcat _Home%/common/lib下。本例以oracle数据库为例,使用的驱动包为:ojdbc14.jar
  •   数据库为Oracle9i
  • 确认在%Tomcat _Home%/common/lib下有jndi.jar、dbc2_0-stdext.jar(tomcat默认有这些包)。
2.配置单个应用的数据源
2.1配置server.xml文件
首先打开%Tomcat _Home%/conf下 server.xml文件,在相应的<Context>中加入<Resource>元素,在<Context>(你的应用配置上下文)中加入以下代码(以oracle为例):

 

<Context path="/Exercise001" reloadable="true" docBase="D:/eclipse/workspace/Exercise001" workDir="D:/eclipse/workspace/Exercise001/work/org/apache/jsp" >
<!-- my dataConnectionPool seting here start-->
<Resource name="jdbc/myoracle" scope="Shareable" type="javax.sql.DataSource"/>
         <ResourceParams name="jdbc/myoracle">
                      <parameter>
                                 <name>factory</name>                                                                            
                                 <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
                      </parameter>
                      <parameter>
                                <name>maxWait</name>
                               <value>5000</value>
                      </parameter>
                      <parameter>
                                  <name>maxActive</name>
                                  <value>4</value>
                      </parameter>
                      <parameter>
                                 <name>password</name>
                                  <value>train</value>
                      </parameter>
                      <parameter>
                                  <name>url</name>                                     
                                  <value>jdbc:oracle:thin:@database-cn:1521:train007</value>
                      </parameter>
                      <parameter>
                                  <name>driverClassName</name>

 

注意:oracle9i以上加载此驱动,而其它版本加载:racle.jdbc.OracleDriver

                                  <value>oracle.jdbc.driver.OracleDriver</value>

 

                      </parameter>
                      <parameter>
                                 <name>maxIdle</name>
                                  <value>2</value>
                      </parameter>
                      <parameter>
                                  <name>username</name>
                                  <value>train</value>
                      </parameter>
           </ResourceParams>
           <!-- my datapool seting here end-->
</Context>
 

 

2.2< Resource >配置说明如下:
属性
描述
name
指定ResourceJNDI的名字
auth
指定管理ResourceManager,由两个可选值ContainerApplicationContainer表示由容器来建和管理ResourceApplication表示由WEB用来建和管理Resource。如果在web application deployment descriptor中使用<resource-ref>个属性是必需的,如果使用<resource-env-ref>个属性是可的。
type
指定Resource所属的java
2.3<ResourceParams>元素的属性如下:
属性
描述
name
指定ResourceParamsJNDI的名字,必Resourcename保持一致
factory
指定生成DataSource象的factory
maxActive
指定数据库连接池中于活的数据库连接最大数目,0表示不受限制
maxIdle
指定数据库连接池中于空的数据库连接的最大数目,0表示不受限制
maxWait
指定数据库连接池中的数据库连于空的最长时间毫秒),超过这一事件,将会抛出异常。-1表示可以无限期等待。
username
指定接数据的用
password
指定接数据的密
driverClassName
指定接数据JDBC驱动程序
url
指定接数据URL
2.3引用数据源
如果在web应用中访问了由Servlet容器管理的某个JNDI Resource,则必须在web.xml中声明对这个JNDI Resource的引用。表示资源引用的元素为<resource-ref>,该元素加在<wepapp></ wepapp >中。
打开你的应用配置文件web.xml,输入以下粗体部分:
<wepapp>
……
<resource-ref>
<descryiption>DB Connection</descryiption>
<res-ref-name>
 jdbc/myoracle
 </res-ref-name>
<res-type>javax.sql.DataSource </res- type>
<res-auth>Container </res-auth>
</resource-ref>
</ wepapp >
24<resource-ref>元素的属性如下:
属性
描述
description
所引用的源的
res-ref-name
指定所引用源的JNDI名字,与<Resource>元素中的name属性保持一致
res-type
指定所引用源的名字,与<Resource>元素中的type属性保持一致
res-auth
指定所引用源的Manager,与<Resource>元素中的auth属性保持一致
2.5测试数据源
     首先,检查Tomcat的%Tomcat _Home%/common/lib下有commons-collections.jar、commons-dbcp.jar、commons-pool.jar包,如果没现有,请到此地下载:http://tomcat.apache.org/
     注意以上三个包不要引入你的工程类路径,否则可能报错。
     然后,将驱动包放入%Tomcat _Home%/common/lib下,注意包必须为.jar后缀。Tomcat只认.jar包。
配置完成后,写个测试,如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD 
HTML 4.01 Transitional//EN">
<html>
<head>
</head>
<body>
<%
Context initContext = new InitialContext();
Context envContext = (Context) initContext.lookup("java:/comp/env");
DataSource db = (DataSource)envContext.lookup("
jdbc/myoracle ");


Connection conn = db.getConnection( );
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM 
test");
while(rs.next()){
out.print(rs.getString("admin_name")+" ");
out.print(rs.getString("admin_password")+"<br>");
}
rs.close();
stmt.close();
conn.close();

%>
</body>
</html>

如果输出你期望的结果,表示数据源配置成功。
3.配置容器全局数据源
   以上,配置的数据源为单个应用使用的数据源,只能为单个应用所使用,下面我们配置全局的数据源,所有的应用都可以使用,通过引用很自然的使用全局数据源。准备工作同上。
          3.1 配置server.xml文件
首先打开%Tomcat _Home%/conf下 server.xml文件,在<GlobalNamingResources>下输入以下粗体部分:
<GlobalNamingResources>
……
<!-- my dataConnectionPool seting here start-->
<Resource name="jdbc/myoracle" scope="Shareable" type="javax.sql.DataSource"/>
<ResourceParams name="jdbc/myoracle">
                      <parameter>

 

此属性必需

                                 <name>factory</name>                                                                            <value>org.apache.commons.dbcp.BasicDataSourceFactory</value>

 

                      </parameter>
                      <parameter>
                      <name>maxWait</name>
                      <value>5000</value>
                      </parameter>
                      <parameter>
                                  <name>maxActive</name>
                                  <value>4</value>
                      </parameter>
                      <parameter>
                                 <name>password</name>
                                  <value>train</value>
                      </parameter>
                      <parameter>
                                  <name>url</name>                                      <value>jdbc:oracle:thin:@database-cn:1521:train007</value>
                      </parameter>
                      <parameter>

 

注意:oracle9i以上加载此驱动,而其它版本加载:racle.jdbc.OracleDriver

                                  <name>driverClassName</name>

 

                                  <value>oracle.jdbc.driver.OracleDriver</value>
                      </parameter>
                      <parameter>
                                 <name>maxIdle</name>
                                  <value>2</value>
                      </parameter>
                      <parameter>
                                  <name>username</name>
                                  <value>train</value>
                      </parameter>
           </ResourceParams>
           <!-- my datapool seting here end-->
</GlobalNamingResources>
3.2 引用数据源

由于我们配置的是容器全局数据源,因此所有的应用都可以引用这个数据源。在你的应用中建立引用,在<Context></Context>之间输入以下粗体部分:

<Context path="/Exercise001" reloadable="true" docBase="D:/eclipse/workspace/Exercise001" workDir="D:/eclipse/workspace/Exercise001/work/org/apache/jsp" >

<ResourceLink name="myDB"
                       global="jdbc/myoracle"

                       type="javax.sql.DataSource"/>

</Context>
3.3 配置应用文件web.xml
打开你的应用配置文件web.xml,输入以下粗体部分:
<wepapp>
……
<resource-ref>
<descryiption>DB Connection</descryiption>
<res-ref-name>
myDB</res-ref-name>
<res-type>javax.sql.DataSource </res- type>
<res-auth>Container </res-auth>
</resource-ref>
</ wepapp >
  3.4测试
  创建测试文件:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ page import="java.sql.*"%>
<%@ page import="javax.naming.*"%>
<%@ page import="javax.sql.*"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD 
HTML 4.01 Transitional//EN">
<html>
<head>
</head>
<body>
<%
Context initContext = new InitialContext();
Context envContext = (Context) initContext.lookup("java:/comp/env");
DataSource db = (DataSource)envContext.lookup("
myDB ");//名称与web.xml配置中的一致


Connection conn = db.getConnection( );
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM 
test");
while(rs.next()){
out.print(rs.getString("admin_name")+" ");
out.print(rs.getString("admin_password")+"<br>");
}
rs.close();
stmt.close();
conn.close();

%>
</body>
</html>

如果输出你期望的结果,表示数据源配置成功。

 

分享到:
评论

相关推荐

    tomcat架构原理剖析

    5. **GlobalNamingResources(全局命名资源)**:这是一个容器级别的命名上下文,可以存放如数据源、JMS队列等资源,这些资源可以在整个Tomcat实例中被多个Web应用程序共享。 6. **Realm(域)**: Realm是Tomcat的...

    Tomcat架构解析文档.zip

    下面我们将详细解析Tomcat的核心架构及其工作原理。 1. **Catalina组件** - **Catalina** 是Tomcat的主要组成部分,负责Servlet和JSP的处理。它实现了Java Servlet和JavaServer Pages(JSP)规范,使得开发者可以...

    TOMCAT原理详解及请求过程

    - 定义数据源。 - 配置环境变量。 #### 四、Tomcat架构及常用组件 - **Server组件** - **定义**:`Server`是Tomcat的顶层容器,它代表了整个服务器实例。 - **属性**: - **port**:接收shutdown指令的端口号...

    How Tomcat Works中文

    本书详细介绍了Tomcat 4.1.12和5.0.18两个版本的内部结构与运作原理,尤其着重于解释Catalina——Tomcat的Servlet容器的核心组成部分。 #### 二、Tomcat的复杂性及组成 Tomcat作为一个功能强大的应用服务器,其...

    数据库连接池配置终极指南

    2. **配置数据源** - 登录到Tomcat的管理界面,找到目标Web应用的数据源配置项。 - 选择新建数据源,设置连接URL、用户名和密码等必要信息。 - 完成配置后,保存并提交更改。 3. **验证配置** - 通过JBuilder...

    tomcat架构解析_刘光瑞(著) 人民邮电出版社_ 2017-05-01.7z

    4. **JNDI**:Java Naming and Directory Interface (JNDI) 提供了一个查找和访问各种命名和目录服务的接口,Tomcat利用JNDI来管理资源,如数据源、邮件会话等。 5. **Cluster**:如果需要实现高可用性和负载均衡,...

    Tomcat8.0底层源码

    在Tomcat中,Web应用的部署主要由`HostConfig`完成,它解析`WEB-INF/web.xml`来创建`Context`对象。`StandardContext`类是`Context`的具体实现,负责管理Servlet和JSP的生命周期。`WebappClassLoader`则负责加载应用...

    解析Tomcat处理请求的类Connector<三>

    【标题】:“解析Tomcat处理请求的类Connector&lt;三&gt;” 在Java的Web服务器领域,Tomcat无疑是最为广泛使用的轻量级应用服务器之一。它以其开源、免费、高效的特点深受开发者喜爱。在这个系列的第三部分,我们将深入...

    tomcat下jar包

    这些JAR文件对于理解Tomcat的工作原理及其与Java应用的交互至关重要。以下是对每个文件的详细解释: 1. **jasper-jdt.jar**:这个JAR文件包含了JSP编译器,它使用Eclipse的JDT(Java Development Toolkit)来将JSP...

    tomcat 9.0

    《深入剖析Tomcat 9.0...通过对Tomcat 9.0源码的深入学习,开发者不仅可以理解Web服务器的工作原理,还能优化性能、解决运行时问题,甚至参与到Tomcat的开发和贡献中。这是一项对Java Web开发者极具价值的技术探索。

    Tomcat 78熵池阻塞变慢详解

    #### 原理解析 ##### SHA1PRNG算法简介 `SHA1PRNG`算法是一种基于SHA-1哈希算法的安全伪随机数生成器。其主要特点是生成的随机数序列具有较强的保密性。在Java中,`SecureRandom`类提供了创建安全随机数的方法,而`...

    运行tomcat源码所要添加的jar包

    以下是一些关键的jar包及其在Tomcat源码运行中的作用: 1. **servlet-api.jar**:这个jar包包含了Servlet API的接口和类,如`javax.servlet.Servlet`、`javax.servlet.http.HttpServlet`等,是开发和运行Servlet...

    TOMCAT源码分析(启动框架)

    本篇文章将深入探讨Tomcat的系统框架及其启动流程,帮助读者理解其内部工作原理。 一、Tomcat系统框架 1. **Catalina核心组件**:Catalina是Tomcat的主要组成部分,负责处理Servlet和JSP。它包含了Engine、Host、...

    tomcat目录结构详解

    - **context.xml**:环境配置文件,主要用于配置数据源,即数据库连接池的设置。 - **tomcat-users.xml**:用户与权限配置文件,定义了哪些用户可以访问Tomcat管理界面,并分配相应的权限。 ##### 3. Lib目录 - *...

    tomcat6源码 工程

    这个压缩包包含了Tomcat6的源代码,对于开发者来说,它是一个深入了解Tomcat工作原理和优化Web应用性能的宝贵资源。下面我们将逐一解析压缩包中的文件,揭示其背后的知识点。 1. `.classpath`:这是一个Eclipse项目...

    tomcat 7 源码分析-4 server初始化背后getServer().init()

    1. 加载全局JNDI资源:Tomcat会解析`conf/server.xml`配置文件,加载全局的JNDI资源,如数据源、连接池等。 2. 初始化Service组件:每个Service在`server.xml`中定义,包含至少一个Engine(容器)用于处理HTTP请求...

    Tomcat解析XML和反射创建对象原理

    在解析XML文件时,通常会用到DOM4J这类第三方的XML解析库,它能够快速解析XML文档并提供丰富的API进行节点查询和数据提取。在给定的代码中,使用了SAXReader类来读取并解析web.xml文件。首先创建一个SAXReader对象,...

    apache-tomcat-7.0.99-src.zip

    7. **JNDI服务**:Tomcat提供了JNDI(Java Naming and Directory Interface)服务,允许应用通过名字查找资源,如数据源或邮件会话。 8. **连接器与协议**:Coyote连接器支持HTTP和AJP协议,解析HTTP请求并生成响应...

Global site tag (gtag.js) - Google Analytics