Apache的数据库连接池 DBCP的常用配置说明,因为项目中用到了需要对其封装,所以必须先了解怎么配置以及各个配置字段的含义,理解的基础上开发我们自己的数据库连接池。可以参考官网dbcp官网

dbcp的配置在下面的配置文件详细介绍

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <!--驱动的名称我用的mysql 所以配置的mysql的驱动名称  -->
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <!--数据库用户名名称  -->
        <property name="username" value="root" />
        <!--数据库的密码 我本地的密码空 所以不用配置  -->
        <property name="password" value="" />
        <!--  数据库连接池启动时创建的连接数量 我设置的是10个-->
        <property name="initialSize" value="10" />
        <!-- 池里不会被释放的最多空闲连接数量。设置为0时表示无限制。 -->
	    <property name="maxIdle" value="5" />
	    <!-- 在不新建连接的条件下,池中保持空闲的最少连接数。 -->
	    <property name="minIdle" value="5" />
	    <!--同一时间可以从池分配的最多连接数量。设置为0时表示无限制。  -->
	    <property name="maxActive" value="10" />
	    <!--  -->
	    <property name="removeAbandoned" value="true" />
	    <!-- 自动回收超时时间(以秒数为单位) -->
	    <property name="removeAbandonedTimeout" value="180" />
	    <!--超时等待时间以毫秒为单位-->
	    <property name="maxWait" value="3000" />
	    <!-- 默认的SQL语句自动提交状态(开启或关闭)设置由连接池本身设置(false由连接池定),不设置该值setAutoCommit方法不被调用; -->
	    <property name="defaultAutoCommit" value="false" />
	    <!--要求必需是个SELECT类型的SQL语句,至少返回一行,由于它会在所有应用的SQL语句执行之前运行一次,
	              所以原则上应该对数据库服务器带来的压力越小越好,推荐使用“SELECT 1”  -->
	    <property name="validationQuery">
	        <value>SELECT 1</value>
         </property>
         <!-- 表示从连接池中获取连接前是否运行validationQuery,true=运行[默认],false=不运行 -->
	    <property name="testOnBorrow">
	        <value>true</value>
	    </property>
	    <!--表示将连接归还连接池前是否运行validationQuery,true=运行,false=不运行[默认];  -->
	    <property name="testOnReturn">
	        <value>false</value>
	    </property>
</bean>  

自定义解析xmld对应的配置xml信息。

<?xml version="1.0" encoding="UTF-8"?>
<da2s-configuration>
	<DefaultConnectionPool>3000</DefaultConnectionPool>
	<connectionPool name="3000">
		<dbtype>MYSQL</dbtype>
		<driverClassName>com.mysql.jdbc.Driver</driverClassName>
		<url>jdbc:mysql://localhost:3306/springok</url>
		<username>root</username>
		<password></password>
		<datasourceProperty>
			<defaultAutoCommit>false</defaultAutoCommit>
			<initialSize>10</initialSize>
			<maxActive>10</maxActive>
			<maxIdle>5</maxIdle>
			<minIdle>5</minIdle>
			<maxWait>3000</maxWait>
			<validationQuery>select 1</validationQuery>
			<testOnBorrow>true</testOnBorrow>
			<removeAbandoned>true</removeAbandoned>
			<removeAbandonedTimeout>180</removeAbandonedTimeout>
			<logAbandoned>true</logAbandoned>
		</datasourceProperty>
	</connectionPool>

	<connectionPool name="5000">
		<dbtype>MYSQL</dbtype>
		<driverClassName>com.mysql.jdbc.Driver</driverClassName>
		<url>jdbc:mysql://localhost:3306/springok</url>
		<username>root</username>
		<password></password>
		<datasourceProperty>
			<defaultAutoCommit>false</defaultAutoCommit>
			<initialSize>10</initialSize>
			<maxActive>10</maxActive>
			<maxIdle>5</maxIdle>
			<minIdle>5</minIdle>
			<maxWait>3000</maxWait>
			<validationQuery>select 1</validationQuery>
			<testOnBorrow>true</testOnBorrow>
			<removeAbandoned>true</removeAbandoned>
			<removeAbandonedTimeout>180</removeAbandonedTimeout>
			<logAbandoned>true</logAbandoned>
		</datasourceProperty>
	</connectionPool>
</da2s-configuration>

思考的起点:

  1. xml如何读取比较方便。
  2. xml如何应该新需求变化xml结构变化。
  3. 读取后的xml内容如何封装。
  4. 程序如何能够访问conn 如何封装。
  5. 客户端如何能很容易的调用开发的功能。
  xml解析使用Apache
Commons Configuration
框架具体使用参考xml解析(common configuratin使用)。下一章节我们设计如何封装一个数据库连接池和解析的具体方法。




mysql数据库连接池使用(一)dbcp方式的配置的更多相关文章

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

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

  2. python3 实现mysql数据库连接池

    首先声明一下,这篇博客进行了通过自己的代码方式,加上这篇博客,最后总结出这段代码.参考博客连接:http://blog.csdn.net/zbc1090549839/article/details/5 ...

  3. 一个简单的MySql数据库连接池的实现

    package cn.hc.connectionPool; import java.io.IOException; import java.io.InputStream; import java.sq ...

  4. Python实现Mysql数据库连接池

    python连接Mysql数据库: python编程中可以使用MySQLdb进行数据库的连接及诸如查询/插入/更新等操作,但是每次连接mysql数据库请求时,都是独立的去请求访问,相当浪费资源,而且访 ...

  5. mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息

    1.1. mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息 有时候我们想要获取到数据库的基本信息,当前程序连接的那个数据库,数据库的版本信息,数据库中有哪些表,表中都有什么字段 ...

  6. MySql数据库连接池专题

    MySql数据库连接池专题 - aspirant - 博客园https://www.cnblogs.com/aspirant/p/6747238.html

  7. Druid数据库连接池及内置监控的配置和使用

    Druid介绍 Druid首先是一个数据库连接池,并且是目前最好的数据库连接池,在功能.性能.扩展性方面,都超过其他数据库连接池,包括DBCP.C3P0.BoneCP.Proxool.JBoss Da ...

  8. MySql数据库连接池

    1.传统链接(如下为示意图) 注意: (1).传统方式找DriverManager要连接,数目是有限的. (2).传统方式的close(),并没有将Connection重用,只是切断应用程序和数据库的 ...

  9. 主流Java数据库连接池分析(C3P0,DBCP,TomcatPool,BoneCP,Druid)

    主流数据库连接池 常用的主流开源数据库连接池有C3P0.DBCP.Tomcat Jdbc Pool.BoneCP.Druid等 C3p0: 开源的JDBC连接池,实现了数据源和JNDI绑定,支持JDB ...

随机推荐

  1. hdu 5607 BestCoder Round #68 (矩阵快速幂)

    graph  Accepts: 9 Submissions: 61  Time Limit: 8000/4000 MS (Java/Others)  Memory Limit: 65536/65536 ...

  2. [bzoj1143][CTSC2008]祭祀

    题意:给定一个n个点m条边的有向无环图,你要选出最多的点,并且满足任意两点之间都不存在通路.2)输出每个点选了它之后还是否有最优解.   n<=100 m<=1000 题解:每个点拆两个点 ...

  3. BZOJ2989 数列(二进制分组)

    这题其实可以cdq分治做,但是如果强制在线的话,这里有个牛逼方法叫二进制分组. 它的基本思想是把修改操作按二进制分组,遇到修改就在尾部加一个,并与之前的合并,比如之前有23(16+4+2+1)个,加了 ...

  4. 树链剖分模板(BZOJ3083)

    实现了路径修改,子树查询,及换根. 换根其实很简单,分三种情况讨论,画画图就明白了. #include <cstdio> #include <algorithm> using ...

  5. Java Servlet 笔记2

    1. Servlet的生命周期 Servlet 通过调用 init () 方法进行初始化. Servlet 调用 service() 方法来处理客户端的请求. Servlet 通过调用 destroy ...

  6. C语言成语设计第一次作业

    一 1.求圆面积和周长 输入圆的半径,计算圆的周长和面积. 2.流程图 3.测试数据及运行结果 测试数据:r=7 运行结果 4.实验分析 问题:第一次输入提示时未加双引号 解决办法:发现问题后加了双引 ...

  7. JAVA NIO工作原理及代码示例

    简介:本文主要介绍了JAVA NIO中的Buffer, Channel, Selector的工作原理以及使用它们的若干注意事项,最后是利用它们实现服务器和客户端通信的代码实例. 欢迎探讨,如有错误敬请 ...

  8. H3C交换机如何配置管理VLAN

    1.输入"system-view"(简写"sys"),进入系统配置模式[H3C],2.下面就可以开始取消默认管理vlan了,输入"undo inter ...

  9. C语言 递归 汉诺塔问题 最大公约数问题

    函数不能嵌套定义,但能嵌套调用(在调用一个函数的过程中再调用另一个函数) 函数间接或直接调用自己,称为递归调用  汉诺塔问题 思想:简化为较为简单的问题 n=2 较为复杂的问题,采用数学归纳方法分析 ...

  10. AnyConnect使用说明(电脑版Windows)

    一.下载客户端 Anyconnect支持Windows.Mac电脑. 二.安装 1.双击打开下载的文件,点“Next”开始安装. 2.选择“I accept …”,再点下一步. 3.点“Install ...