spring配置数据源连接池

spring配置详解-连接池配置(转载)

一、连接池概述

 数据库连接池概述:

  数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显著影响到整个

应用程序的伸缩性和健壮性,影响到程序的性能指标。数据库连接池正是针对这个问题提出来的。

  数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;释放空闲时

间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。

  数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些

数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接

数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池的最小连接数和最大连接数的设

置要考虑到下列几个因素:

  1) 最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;

  2) 最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之

后的数据库操作。

  3) 如果最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库

连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。

目前常用的连接池有:C3P0、DBCP、Proxool

网上的评价是:

C3P0比较耗费资源,效率方面可能要低一点。

DBCP在实践中存在BUG,在某些种情会产生很多空连接不能释放,Hibernate3.0已经放弃了对其的支持。

Proxool的负面评价较少,现在比较推荐它,而且它还提供即时监控连接池状态的功能,便于发现连接泄漏的情况。

配置如下:

1、在spring配置文件中,一般在applicationContext.xml中

<bean id="proxoolDataSource" class="org.logicalcobwebs.proxool.ProxoolDataSource">

<property name="driver" value="${jdbc.connection.driverClassName}"/>

<property name="driverUrl" value="${jdbc.connection.url}"/>

<property name="user" value="${jdbc.connection.username}"/>

<property name="password" value="${jdbc.connection.password}"/>

<!-- 测试的SQL执行语句 -->

<property name="houseKeepingTestSql" value="${proxool.houseKeepingTestSql}"/>

<!-- 最少保持的空闲连接数 (默认2个) -->

<property name="prototypeCount" value="${proxool.prototypeCount}"/>

<!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁 默认30秒) -->

<property name="houseKeepingSleepTime" value="${proxool.hourseKeepingSleepTime}"/>

<!-- 最大活动时间(超过此时间线程将被kill,默认为5分钟) -->

<property name="maximumActiveTime" value="${proxool.maximumActiveTime}"/>

<!-- 连接最长时间(默认为4个小时) -->

<property name="maximumConnectionLifetime" value="${proxool.maximumConnectionLifetime}"/>

<!-- 最小连接数 (默认2个) -->

<property name="minimumConnectionCount" value="${proxool.minimumConnectionCount}"/>

<!-- 最大连接数 (默认5个) -->

<property name="maximumConnectionCount" value="${proxool.maximumConnectionCount}"/>

<!-- -->

<property name="statistics" value="${proxool.statistics}"/>

<!-- 别名 -->

<property name="alias" value="${proxool.alias}"/>

<!-- -->

<property name="simultaneousBuildThrottle" value="${proxool.simultaneous-build-throttle}"/>

</bean>

然后注入到sessionFactory中

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">

<property name="dataSource" ref="proxoolDataSource"/>

</bean>

Porxool 配置文件

--==--==--==--==--==<proxool.xml>==--==--==--==--==--==--==

<?xml version="1.0" encoding="UTF-8"?>

<proxool>

<alias>WMS</alias>

<driver-url>jdbc:postgresql://192.168.210.184:5432/wms</driver-url>

<driver-class>org.postgresql.Driver</driver-class>

<driver-properties>

<property name="user" value="wms_user" />

<property name="password" value="wms" />

</driver-properties>

<minimum-connection-count>2</minimum-connection-count>

<maximum-connection-count>40</maximum-connection-count>

<simultaneous-build-throttle>20</simultaneous-build-throttle>

<prototype-count>2</prototype-count>

<house-keeping-test-sql>select CURRENT_DATE</house-keeping-test-sql>

</proxool>

--==--==--==--==--==<proxool.xml>==--==--==--==--==--==--==

配置说明:

alias                                          -〉数据库连接别名(程序中需要使用的名称)

driver-url                                   -〉数据库驱动

driver-class                                -〉驱动程序类

driver-properties                        -〉联机数据库的用户和密码

minimum-connection-count          -〉最小连接数量,建议设置0以上,保证第一次连接时间

maximum-connection-count         -〉最大连接数量,如果超过最大连接数量则会抛出异常。连接数设置过多,服务器CPU和内存性能消耗很

大。

simultaneous-build-throttle          -〉同时最大连接数

prototype-count                          -〉一次产生连接的数量。

例:如果现在prototype-count设置为4个,但是现在已经有2个可以获得的连接,那么

将会试图再创建2个连接。

但不能超过最大连接数。

maximum-active-time                 -〉连接最大时间活动 默认5分钟

maximum-connection-lifetime      -〉连接最大生命时间 默认4小时

spring配置数据源连接池

时间: 2024-08-02 11:04:20

spring配置数据源连接池的相关文章

搭建spring工程配置数据源连接池

Spring作为一个优秀的开源框架,越来越为大家所熟知,前段时间用搭了个spring工程来管理数据库连接池,没有借助Eclipse纯手工搭建,网上此类文章不多,这里给大家分享一下,也作为一个手记. 工程结构: 注意:src目录下的applicationContext.xml是单元测试用的,作为web工程的话就使用WEB-INF下的applicationContext.xml. 1.下载jar包 这里需要下载很多spring的jar包,推荐去官网下载,很多人会说官网只提供maven和gradle下

Spring 配置JNDI连接池

一.打开Tomcat/conf/context.xml文件,在标签<context></<context>中加入如下内容: <Resource  name="jdbc/testDBS"        auth="Container"            type="javax.sql.DataSource"            driverClassName="com.mysql.jdbc.Dri

spring配置c3p0连接池

Spring之c3p0连接池配置和使用

1.导入包:c3p0和mchange包 2.代码实现方式: 1 package helloworld.pools; 2 3 import com.mchange.v2.c3p0.ComboPooledDataSource; 4 import org.springframework.jdbc.core.JdbcTemplate; 5 import java.beans.PropertyVetoException; 6 7 /** 8 * c3p0连接池使用方法-代码 9 * 导入包:c3p0和mc

spring的RestTemplate连接池相关配置

import org.apache.http.conn.HttpClientConnectionManager; import org.apache.http.impl.client.HttpClientBuilder; import org.apache.http.impl.conn.PoolingHttpClientConnectionManager; import org.springframework.boot.web.client.RestTemplateBuilder; import

Spring配置数据源的常用方式

Spring配置数据源的常用方式 在应用程序中配置数据源 (1).在classpath中创建连接参数的配置文件,如db-config.properties,内容如下: driverClass=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/zzp username=root password=admin (2).在Spring的配置文件中引入参数配置文件,代码如下: <!-- 配置spring资源文件 --> <bean id=

【转】SSH中 整合spring和proxool 连接池

[摘要:比来做的一个项目中应用到了毗邻池技巧,大概我们人人比拟认识的开源毗邻池有dbcp,c3p0,proxool.对那三种毗邻池来讲,从机能战失足率来讲,proxool轻微比前两种好些.本日我首要简略] 最近做的一个项目中运用到了连接池技术,可能我们大家比较熟悉的开源连接池有dbcp,c3p0,proxool.对这三种连接池来说,从性能和出错率来说,proxool稍微比前两种好些.今天我主要简单的讲述一下proxool,我在项目中成功的配置和源码. 第一步:首先去http://proxool.

DBCP数据源连接池实现原理分析

前些天在调试公司系统的时候发现这样的一个问题:mysql数据库服务停止一段时间后再次重启后吗,tomcat服务无法请求数据库服务,调试了半天对这个问题进行定位解决,期间也搞了很多有关mysql数据库的知识,包括数据库连接池的问题,以前没有遇到问题的时候只知道数据库连接池这个概念和如何配置,但是当遇到问题的时候就要去看怎么实现了,比如很简单的默认的数据库连接池的个数是多少呢,我相信没有看过源代码的是不知道的,答案是8.下面就针对最近学习的org.apache.commons.dbcp.BasicD

《java数据源—连接池》

<java数据源-连接池>1.数据源的分类:直接数据源.连接池数据源.2.连接池.数据源.JNDI a.数据源:Java中的数据源就是连接到数据库的一条路径,数据源中并无真正的数据,它仅仅记录的是你连接到哪个数据库,以及如何连接. b.连接池:简单的说就是保存所有的数据库连接的地方,在系统初始化时,将数据库连接对象存储到内存里,当用户需要访问数据库的时候,并不是建立一个新的连接,而是从连接池中 取出一个已经建立好的空闲连接对象.而连接池负责分配.管理.释放数据库连接对象.注意的是:连接池是由容