JDBC的问题

在程序中,我们经常要建立与数据库的连接,之后再关闭这个连接。我们知道,数据库连接对象的创建是比较消耗系统性能的,这些频繁的操作势必会消耗大量的系统资源。因此我们需要采用更高效的数据库访问技术。

数据库连接池的概念

在JDBC2.0中提出了数据库连接池技术,它提供了javax.Sql.DataSource(数据源)接口,它负责建立与数据库的连接。通过客户之间共享一组连接,而不是在它们需要的时候为他们新建立连接,这样就可以改善资源的使用,提高应用程序的响应能力。

连接池技术的核心思想

连接池技术的核心思想是:连接复用。通过建立一个数据库连接池以及一套连接使用、分配、治理策略,是的该连接池的连接可以得到高效、安全的复用,避免了数据库连接的频繁建立、关闭的开销。

基于JDBC的数据库连接池技术

数据库连接池技术是基于JDBC技术的,对JDBC的原始连接进行了封装,从而提高了开发效率。

数据源的创建与JNDI资源

DataSource的创建

DataSource对象由Web容器提供,因此不能再程序中采用创建一个实例的方式来生成DataSource对象。

DataSource的获取

当启动Web容器之后,Web容器创建DataSource对象,之后就通过JNDI技术来获得DataSource对象。

DataSource创建、获取的基本流程

由于DataSource对象是有Web容器提供的,但Web程序不会平白无故的创建DataSource,必须通过一个"消息"通知Web容器要创建数据源对象。通常我们用的Web容器时Tomcat,在Tomcat中这个"消息"就是一个XML配置文件,通过context.xml文件配置数据源。

在Tomcat的安装路径下的conf 目录下有一个context.xml文件。当启动Tomcat后,Tomcat会加载一系列的配置文件,并且解析配置文件中的内容,当然也包括context.xml文件。当Tomcat检查到context.xml文件中有数据源对象的配置时,Tomcat就会跟数据源配置信息创建相应的数据库连接。在创建数据源的过程中,Tomcat会根据配置信息,比如说:数据源的名称、数据源的类型、数据源数据连接的最大数目、数据库连接的最大空闲时间等信息创建出相应的连接,形成数据库连接池。

之后在程序中通过JNDI技术,根据数据源的名称查找到相应的数据库连接池,获取连接,供程序使用。

JNDI的配置

Tomcat把DataSource作为一种可配置的JNDI资源来处理。其配置如下:

<Context>

……

<Resource name="jdbc/books" auth="Container" type="javax.sql.DataSource" maxActive="1000" maxIdle="30" maxWait="10000" username="sa" password="sa"

driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"

url="jdbc:sqlserver://localhost:1433; DatabaseName=books"

/>

</Context>

通过JNDI在程序中获取DataSource

在程序中,通过javax.naming.Context对象获得DataSource对象,如下:

Context cxt = new InitialContext();

当Web容器加载到该句代码时,当完成创建实例后,Context对象就获取了DataSource对象

之后通过Context对象的lookup方法查找出数据源,该方法的参数是以"java:comp/env"为前缀,以配置文件中的数据源的名称结尾的字符串。如下:

DataSource ds = (DataSource)cxt.lookup("java:comp/env/jdbc/books");

取得一个数据源之后,将其转换为DataSource对象。

获得DataSource之后,便通过DataSource对象取得Connection,如下:

Connection conn = ds.getConnection();

有了Connection对象之后就可以对数据进行其他操作了。

http://blog.163.com/qqabc20082006@126/blog/static/22928525201021661922648/

【Java】数据库连接池技术的更多相关文章

  1. java数据库连接池技术原理(浅析)

    在执行数据库SQL语句时,我们先要进行数据连接:而每次创建新的数据库的连接要消耗大量的资源,这样,大家就想出了数据库连接池技术.它的原理是,在运行过程中,同时打开着一定数量的数据库连接,形成数据连接池 ...

  2. java数据库连接池技术简单使用

    JDBCDemo.java: package com.itheima.jdbc; import java.sql.Connection; import java.sql.PreparedStateme ...

  3. Java数据库连接池详解

    http://www.javaweb1024.com/java/JavaWebzhongji/2015/06/01/736.html 对于共享资源,有一个很著名的设计模式:资源池(Resource P ...

  4. Java学习:数据库连接池技术

    本节内容 数据库连接池 Spring JDBC : JDBC Template 数据库连接池 1.概念:其实就是一个容器(集合),存放数据库连接的容器 当系统初始化好后,容器中会申请一些连接对象,当用 ...

  5. .数据库连接池技术:DBCP和C3P0

    数据库连接池技术:DBCP和C3P0 1.什么是数据库连接池 已知的方法是需要访问数据库的时候进行一次数据库的连接,对数据库操作完之后再释放这个连接,通常这样业务是缺点很明显的: 用户每次请求都需要向 ...

  6. Java数据库连接池

    转载过来的,最近在做一个小网站,准备使用这种方法.     Java jdbc数据库连接池总结! 1. 引言 近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及, ...

  7. java数据库连接池dbcp的使用

    近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及,计算机 应用程序已从传统的桌面应用转到Web应用.基于B/S(Browser/Server)架构的3层开发模式 ...

  8. 基于JDBC的数据库连接池技术研究与应用

    引言 近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及,计算机 应用程序已从传统的桌面应用转到Web应用.基于B/S(Browser/Server)架构的3层开 ...

  9. Java数据库连接池封装与用法

    Java数据库连接池封装与用法 修改于抄袭版本,那货写的有点BUG,两个类,一个用法 ConnectionPool类: package com.vl.sql; import java.sql.Conn ...

随机推荐

  1. RFC 文档(中文与英文)

    http://man.chinaunix.net/develop/rfc/default.htm https://www.rfc-editor.org/retrieve/ http://www.iet ...

  2. IOS 整理

    防止程序进入休眠状态 设置应用程序的 idleTimerDisabled 属性为 YES (默认为NO) [UIApplication sharedApplication].idleTimerDisa ...

  3. Chapter 5 - How to Detect the Collisions

    Chapter 5 - How to Detect the Collisions Our hero can fire bullets now, but the bullets are only vis ...

  4. JDBC操作数据库 封装好的工具类

    mysql sqlserver oracle 数据库的驱动jar包http://download.csdn.net/download/csdn576038874/8833683package cn.h ...

  5. yii2 验证码的使用

    @see  http://www.yiiframework.com/doc-2.0/yii-captcha-captcha.html 以下根据 MVC 模型的顺序来添加代码 1. model 层, 或 ...

  6. mybatis缓存清除方法

    String cacheName = IWenshiduDao.class.getName(); Ehcache cache = CacheManager.create().getEhcache(ca ...

  7. 程序员带你十天快速入门Python,玩转电脑软件开发(二)

    关注今日头条-做全栈攻城狮,学代码也要读书,爱全栈,更爱生活.提供程序员技术及生活指导干货. 如果你真想学习,请评论学过的每篇文章,记录学习的痕迹. 请把所有教程文章中所提及的代码,最少敲写三遍,达到 ...

  8. CSS中Position属性

    也许你看到这个标题觉得很简单,确实这是一篇关于CSS中Position属性基础知识的文章,但是关于Position的一些细节也许你不了解. 1.简介 position有五个属性: static | r ...

  9. getSharedPreferences()与getSharedPreferences()与getDefaultSharedPreferences()的区别

    http://blog.csdn.net/ah200614435/article/details/7869681 一直迷惑于这三个方法的关系,最近忙完项目,好好的分析一下. 如果你熟悉Context那 ...

  10. jsp中<c:if>与<s:if>的区别

    <c:if>时jstl标签,一般与el表达式一起使用,参考http://www.360doc.com/content/11/1121/16/7874148_166229306.shtml ...