jakarta commons-dbcp

jakarta commons-dbcp

1.DBCP简介网络程序的设计,很多都涉及到和关系型数据库的交互操作,一般的操作方式都是使用的时候创建到数据库的连接,然后进行各种操作,这种简单的操作方式带来的问题便是数据库的频繁的打开和关闭,以及Transtion的执行,这是一种很耗费时间和资源的操作。于是数据库缓冲池DBCP就出现了,这个包是从pool包发展出来的。

2.DBCP实现的基本流程 1.创建enericObjectPool实例 GenericObjectPool pool = new GenericObjectPool(null); 2.创建PoolableConnectionFactory DriverManagerConnectionFactory cf = new DriverManagerConnectionFactory( "jdbc:mysql://host/db", "username", "password");
PoolableConnectionFactory pcf = new PoolableConnectionFactory( CF, pool, null, "SELECT * FROM mysql.db", false, true); 3.创建和注册PoolingDriver new PoolingDriver().registerPool("myPool", pool); 到此为止,数据库缓冲池就创建完毕了.

3.DataSource的实现过程 DataSource在众多的jsp容器和应用程序中都已经实现,在容器或者应用服务器启动的时候,他会读取相关的配置文件,自动完成DataSource的创建工作,我们一般只需要在服务器的配置文件中指定就可以了,这里贴出实现的过程,便于大家理解它内部的实现机制,便于编程参考。

import javax.sql.DataSource;

import java.sql.Connection;

import java.sql.Statement;

 import java.sql.ResultSet;

import java.sql.SQLException;

 import org.apache.commons.dbcp.BasicDataSource;

public class BasicDataSourceExample {
   public static void main(String[] args) {

  // 创建BasicDataSource 

    System.out.println("Setting up data source.");

    DataSource dataSource = setupDataSource(args[0]);   

   System.out.println("Done.");
   //创建JDBC数据源

   Connection conn = null;

   Statement stmt = null;  

   ResultSet rset = null;
   try {

        System.out.println("Creating connection.");

         conn = dataSource.getConnection();

         System.out.println("Creating statement.");

         stmt = conn.createStatement();

         System.out.println("Executing statement.");

        rset = stmt.executeQuery(args[1]);

        System.out.println("Results:");

        int numcols = rset.getMetaData().getColumnCount();

       while(rset.next())

       {

           for(int i=1;i<=numcols;i++)

          { 

                System.out.print("\t" + rset.getString(i));

           }

           System.out.println("");

         } 

      } catch(SQLException e) { e.printStackTrace(); }

         finally {

              try {

                    rset.close();

              } catch(Exception e) { }

           try { stmt.close(); } catch(Exception e) { }

           try { conn.close(); } catch(Exception e) { } } }

          //创建数据源

        public static DataSource setupDataSource(String connectURI)

          {

                 BasicDataSource ds = new BasicDataSource();

                   ds.setDriverClassName("oracle.jdbc.driver.OracleDriver");

                ds.setUsername("scott");

                ds.setPassword("tiger");

                ds.setUrl(connectURI); return ds;

          }

           //提示数据源状态

          public static void printDataSourceStats(DataSource ds) throws SQLException {

          BasicDataSource bds = (BasicDataSource) ds;              

         System.out.println("NumActive: " + bds.getNumActive());

         System.out.println("NumIdle: " + bds.getNumIdle());

       }

  //关闭数据源

public static void shutdownDataSource(DataSource ds) throws SQLException { 

          BasicDataSource bds = (BasicDataSource) ds;

         bds.close(); } }

例子比较简单,不再多说了~ 4.tomcat中DBCP的配置这里是以Mysql作为数据库进行说明。使用DBCP,在 server.xml 中需要设置相关的连接及 dbcp 的参数值.
factory org.apache.commons.dbcp.BasicDataSourceFactory maxActive 100 maxIdle 30 maxWait 10000 username root password admin driverClassName org.gjt.mm.mysql.Driver url jdbc:mysql://localhost:3306/javatest?autoReconnect=true 我们可以看到他使用的 dbcp factory 就是 org.apache.commons.dbcp.BasicDataSourceFactory 5.参数说明 *dataSource:要连接的 datasource (通常我们不会定义在 server.xml) *defaultAutoCommit:对于事务是否 autoCommit, 默认值为 true *defaultReadOnly:对于数据库是否只能读取, 默认值为 false *driverClassName:连接数据库所用的 JDBC Driver Class, *maxActive:最大连接数据库连接数,设 0 为没有限制 *maxIdle:最大等待连接中的数量,设 0 为没有限制 *maxWait:最大等待秒数, 单位为 ms, 超过时间会丟出错误信息 *password:登陆数据库所用的密码 *url:连接数据库的 URL *username:登陆数据库所用的帐号 *validationQuery:验证连接是否成功, SQL SELECT 指令至少要返回一行 *removeAbandoned:是否自我中断, 默认是 false *removeAbandonedTimeout:几秒后会自我中断, removeAbandoned 必须为 true *logAbandoned:是否记录中断事件, 默认为 false 6.总结 DBCP一般应用在数据库的使用非常频繁的情况下使用,它可以处理大量的数据库的连接请求,不失为做大型站点的首选数据库配置 7.参考资料 *jakarta commons http://jakarta.apache.org/commons/ *jakarta commons-dbcp http://jakarta.apache.org/commons/dbcp *jakarta commons-dbcp api

资源简介 Jakarta commons docs API CHM 格式带索引和全文搜索,方便携带和查询。 Jakarta commons 包含很多可复用的通用组件。 commons-attributes 让开发者可以使用 C# 或 .net 样式的 attributes, 是一种运行时的 api, 有点类似 doclet commons-beanutils 提供对 Java 反射和自省API的包装 commons-betwixt 这个组件提供一个XML自省(introspection)机制用来把Java Bean映射到XML文档 commons-chain 提供实现组织复杂的处理流程的“责任链模式” commons-cli 命令行参数解析 , 由 Werken, Avalon 和 Optz 组成 commons-codec 包含一些通用的编码解码算法。包括一些语音编码器, Hex, Base64, 以及URL encoder. commons-collections 扩充了 java.util.collection 接口 commons-compress 操作压缩文件的 API commons-configuration 可以从xml、properties、JNDI、JDBC、System properties、Applet parameters和Servlet parameters等读取信息 commons-daemon 可以帮你实现将一个普通的 Java 应用变成系统的一个后台服务 commons-dbcp 数据连接池服务 commons-dbutils JDBC 辅助类 commons-digester XML 文件到 Java 对象的映射机制 commons-discovery 提供工具来定位资源 (包括类) ,通过使用各种模式来映射服务/引用名称和资源名称。 commons-el 提供在JSP2.0规范中定义的EL表达式的解释器. commons-email 提供一组用于发送Email的API,它基于Java Mail API基础之上并进行了简化 commons-exec 处理外部进程的执行或管理外部环境 commons-fileupload 使得在你可以在应用和Servlet中容易的加入强大和高性能的文件上传能力 commons-io 用来帮助进行IO功能开发.它包含三个主要的领域:Utility classes-提供一些静态方法来完成公共任务.Filters-提供文件过滤器的各种实现.Streams-提供实用的Stream,reader与 writer实现 commons-jelly 能够把XML转换成可执行代码,所以Jelly是一个基于XML与Java的脚本和处理引擎 commons-jexl 是一个表达式语言,通过借鉴来自于Velocity的经验扩展了JSTL定义的表达式语言 commons-jxpath 定义了一个简单的XPath表达式语言的解析器.JXPath应用XPath表达式来操纵各种类型的对象包括:JavaBeans,Maps,Servlet contexts,DOM等 commons-lang commons的基础包 commons-launcher 提供多平台的 Java 程序加载 commons-logging 提供日志的实现 commons-math 是一个轻量的,自包含的数学和统计组件,解决了许多非常通用但没有及时出现在Java标准语言中的实践问题. commons-modeler 创建符合 JMX 规范的 MBeans 机制 commons-net 网络和协议实现的集合 commons-pool 提供了通用对象池接口,一个用于创建模块化对象池的工具包,以及通常的对象池实 commons-primitives java 简单类型使用的扩展 commons-proxy 创建动态代理的库 commons-scxml commons-transaction 处理多级事务的集合 commons-validator 提供了一个简单的,可扩展的框架来在一个XML文件中定义校验器 (校验方法)和校验规则 commons-vfs 虚拟文件系统 httpcomponents-client 和 http 协议客户端一起协作的框架 httpcomponents-core jakarta-oro 一套文本处理工具,能提供perl5.0兼容的正则表达式,AWK-like正则表达式, glob表达式。还提供替换,分割,文件名过虑等功能 jakarta-regexp 是一个100%纯java正则式处理包,是Jonathan Locke捐给Apache软件基金会的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值