Tomcat 6 JNDI数据源详解

数据库链接池这个概念应该都不陌生,在Java中链接池也就是数据库的链接池,它是一种采用链接复用的思想避免屡次链接形成资源的浪费机制。html

最多见的链接池就是DBCP和C30P了,在tomcat中默认使用的DBCP的链接池,在Hibernate中则默认使用的是C3P0。他们的区别对于使用者来讲最明显的就是,默认状况下DBCP不提供空闲链接的释放,须要手动开启。java

下面介绍下Tomcat中数据链接池的配置及使用。mysql

 

介绍

  本篇依赖一个概念——JNDI,能够参考前面的博客:JNDI资源详解web

  对于JNDI,能够简单理解成Tomcat中的资源池,经过一些特有的名字与特定的资源相对应,相似一个map,能够简单的经过名字获取到该资源。sql

  那么本篇中JNDI数据源就是经过配置一个数据源的资源,在应用中经过该名称获取到数据库链接,进行操做。这样就省去了每次链接数据库的步骤。数据库

链接池原理

  链接池的概念,应该都不陌生了。部份内容能够参考:几个主流的链接池apache

  这里简单说明下,若是单独在应用使用链接池,可能只是在应用运行时建立链接池。而tomcat配置数据源能够在tomcat容器启动时就初始化链接池,中止tomcat时才释放资源,其部署的应用能够根据JNDI的声明,在应用中共享使用该资源。tomcat

  所以一个是应用中的链接池(即一个应用中不一样的业务使用该链接池,好比注册新用户与购买商品),一个能够扩大到多应用的链接池,具体使用的还要看业务需求。oracle

 

  另外,tomcat中默认使用的DBCP链接池,其jar包位于CATALINA_HOME/lib下,tomcat-dbcp.jarpost

  须要注意的是,默认状况下dbcp不会去释放空闲的链接。好比,咱们在编码时,拿到一个链接执行业务操做,可是没有进行释放。此时,DBCP链接池不会放回到空闲队列中。若是再有新的链接,会分配其余的链接。当链接数目过大时,就会形成链接的阻塞。

  能够经过配置某些属性来自动回收链接,首先设置removeAbandoned="true"开启回收,而后设置removeAbandonedTimeout="300"设置链接的时间,超过该时间就会自动收回。

  具体内容能够参考:DBCP文档

Mysql案例

  按照下面几个步骤:

  1 放置mysql驱动:能够到这里下载

  2 建立数据库插入数据

  3 配置JNDI资源(context.xml以及web.xml)

  4 建立JSP验证结果

  

  1 放置驱动

  在tomcat根目录下的Lib中放置mysql驱动。

  2 建立数据库表并添加数据

  能够参考下面的SQL脚本:

/*
SQLyog v4.05
Host - 4.1.11-nt : Database - test
*********************************************************************
Server version : 4.1.11-nt
*/


create database if not exists `test`;

USE `test`;

/*Table structure for table `test`.`stu` */

drop table if exists `test`.`stu`;

CREATE TABLE `stu` (
  `id` int(11) NOT NULL default '0',
  `name` char(1) default NULL,
  `age` int(11) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

/*Data for the table `test`.`stu` */

insert into `test`.`stu` values (0,'x',26),(1,'z',27),(2,'w',25);

  3 配置JNDI资源

  首先在context.xml中添加<resource>

<Resource name="jdbc/TestDB" auth="Container" type="javax.sql.DataSource"
               maxActive="100" maxIdle="30" maxWait="10000"
               username="root" password="123456" driverClassName="com.mysql.jdbc.Driver"
               url="jdbc:mysql://localhost:3306/test"/>

  其中username为你的用户名,password是密码。

  maxActive指定最大的链接数,maxIdle指定最大的空闲链接数(即没有链接时,保存多少链接),maxWait指定最大的等待链接数。

  而后在web.xml中配置指定的资源名称(不是必须的)

  <resource-ref>
      <description>DB Connection</description>
      <res-ref-name>jdbc/TestDB</res-ref-name>
      <res-type>javax.sql.DataSource</res-type>
      <res-auth>Container</res-auth>
  </resource-ref>

  4 建立JSP页面,输出信息

  按照下面的代码建立,并释放链接:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    import="javax.naming.*,java.sql.*,javax.sql.*"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
    <h2>Results</h2>
    <%
    Context initContext = new InitialContext();
    Context envContext  = (Context)initContext.lookup("java:/comp/env");
    DataSource ds = (DataSource)envContext.lookup("jdbc/TestDB");
    Connection conn = ds.getConnection();
    String sql = "select * from stu";
    PreparedStatement st = conn.prepareStatement(sql);
    ResultSet rs = st.executeQuery();
    while(rs.next()){
        out.println("name:"+rs.getString(2)+" age:"+rs.getInt(3)+"<br>");
    }
    if(rs!=null){
        try{
            rs.close();
        }catch (Exception e) {
            e.printStackTrace();
        }
        rs = null;
    }
    if(st!=null){
        try{
            st.close();
        }catch (Exception e) {
            e.printStackTrace();
        }
    }
    
    if(conn!=null){
        try{
            conn.close();
        }catch (Exception e) {
            e.printStackTrace();
        }
    }
    %>
</body>
</html>

  最后的执行结果:

其余的配置

  其余的配置如Oracle和PostgreSQL仅仅是须要的数据库驱动和建立的JNDI名称不一样:

  例如,在oracle中,context.xml中配置以下:

<Resource name="jdbc/myoracle" auth="Container"
              type="javax.sql.DataSource" driverClassName="oracle.jdbc.OracleDriver"
              url="jdbc:oracle:thin:@127.0.0.1:1521:mysid"
              username="scott" password="tiger" maxActive="20" maxIdle="10"
              maxWait="-1"/> 

  在PostgreSQL中配置以下:

<Resource name="jdbc/postgres" auth="Container"
          type="javax.sql.DataSource" driverClassName="org.postgresql.Driver"
          url="jdbc:postgresql://127.0.0.1:5432/mydb"
          username="myuser" password="mypasswd" maxActive="20" maxIdle="10"
maxWait="-1"/>

  使用方式都是差很少的。

参考

【1】几种主流的链接池:http://developer.51cto.com/art/201006/207768.htm

【2】DBCP官方文档:http://commons.apache.org/proper/commons-dbcp/configuration.html

【3】Tomcat JNDI Database:http://tomcat.apache.org/tomcat-6.0-doc/jndi-datasource-examples-howto.html

相关文章
相关标签/搜索