欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

数据库阿里连接池 druid配置详解

程序员文章站 2024-02-24 14:48:16
java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,有不得不使用数据库连接池。数据库连接池有很多选择,c3p、dhcp、proxool等,druid作为一名后...

java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,有不得不使用数据库连接池。数据库连接池有很多选择,c3p、dhcp、proxool等,druid作为一名后起之秀,凭借其出色的性能,也逐渐印入了大家的眼帘。接下来本教程就说一下druid的简单使用。

首先从 下载最新的jar包。如果想使用最新的源码编译,可以从 下载源码,然后使用maven命令行,或者导入到eclipse中进行编译。

和dbcp类似,druid的配置项如下

配置 缺省值 说明
name   配置这个属性的意义在于,如果存在多个数据源,监控的时候 
可以通过名字来区分开来。如果没有配置,将会生成一个名字, 
格式是:"datasource-" + system.identityhashcode(this)
jdbcurl   连接数据库的url,不同数据库不一样。例如: 
mysql : jdbc:mysql://10.20.153.104:3306/druid2  
oracle : jdbc:oracle:thin:@10.20.149.85:1521:ocnauto
username   连接数据库的用户名
password   连接数据库的密码。如果你不希望密码直接写在配置文件中, 
可以使用configfilter。详细看这里: 
https://github.com/alibaba/druid/wiki/%e4%bd%bf%e7%94%a8configfilter
driverclassname 根据url自动识别 这一项可配可不配,如果不配置druid会根据url自动识别dbtype,然后选择相应的driverclassname
initialsize 0 初始化时建立物理连接的个数。初始化发生在显示调用init方法,或者第一次getconnection时
maxactive 8 最大连接池数量
maxidle 8 已经不再使用,配置了也没效果
minidle   最小连接池数量
maxwait   获取连接时最大等待时间,单位毫秒。配置了maxwait之后, 
缺省启用公平锁,并发效率会有所下降, 
如果需要可以通过配置useunfairlock属性为true使用非公平锁。
poolpreparedstatements false 是否缓存preparedstatement,也就是pscache。 
pscache对支持游标的数据库性能提升巨大,比如说oracle。 
在mysql5.5以下的版本中没有pscache功能,建议关闭掉。
作者在5.5版本中使用pscache,通过监控界面发现pscache有缓存命中率记录, 
该应该是支持pscache。
maxopenpreparedstatements -1 要启用pscache,必须配置大于0,当大于0时, 
poolpreparedstatements自动触发修改为true。 
在druid中,不会存在oracle下pscache占用内存过多的问题, 
可以把这个数值配置大一些,比如说100
validationquery   用来检测连接是否有效的sql,要求是一个查询语句。 
如果validationquery为null,testonborrow、testonreturn、 
testwhileidle都不会其作用。
testonborrow true 申请连接时执行validationquery检测连接是否有效,做了这个配置会降低性能。
testonreturn false 归还连接时执行validationquery检测连接是否有效,做了这个配置会降低性能
testwhileidle false 建议配置为true,不影响性能,并且保证安全性。 
申请连接的时候检测,如果空闲时间大于 
timebetweenevictionrunsmillis, 
执行validationquery检测连接是否有效。
timebetweenevictionrunsmillis   有两个含义: 
1) destroy线程会检测连接的间隔时间 
2) testwhileidle的判断依据,详细看testwhileidle属性的说明
numtestsperevictionrun   不再使用,一个druiddatasource只支持一个evictionrun
minevictableidletimemillis    
connectioninitsqls   物理连接初始化的时候执行的sql
exceptionsorter 根据dbtype自动识别 当数据库抛出一些不可恢复的异常时,抛弃连接
filters   属性类型是字符串,通过别名的方式配置扩展插件, 
常用的插件有: 
监控统计用的filter:stat  
日志用的filter:log4j 
防御sql注入的filter:wall
proxyfilters   类型是list<com.alibaba.druid.filter.filter>, 
如果同时配置了filters和proxyfilters, 
是组合关系,并非替换关系

表1.1 配置属性

加入 druid-1.0.9.jar

applicationcontext.xml

< bean name = "transactionmanager" class ="org.springframework.jdbc.datasource.datasourcetransactionmanager" >   
  < property name = "datasource" ref = "datasource" ></ property > 
   </ bean > 
  < bean id = "propertyconfigurer" class ="org.springframework.beans.factory.config.propertyplaceholderconfigurer" >  
    < property name = "locations" >  
      < list >  
         < value > /web-inf/classes/dbconfig.properties </ value >  
      </ list >  
    </ property >  
  </ bean > 

applicationcontext.xml配置druid 

<!-- 阿里 druid 数据库连接池 --> 
 < bean id = "datasource" class = "com.alibaba.druid.pool.druiddatasource"destroy-method = "close" >  
    <!-- 数据库基本信息配置 --> 
    < property name = "url" value = "${url}" />  
    < property name = "username" value = "${username}" />  
    < property name = "password" value = "${password}" />  
    < property name = "driverclassname" value = "${driverclassname}" />  
    < property name = "filters" value = "${filters}" />  
    <!-- 最大并发连接数 --> 
    < property name = "maxactive" value = "${maxactive}" /> 
    <!-- 初始化连接数量 --> 
    < property name = "initialsize" value = "${initialsize}" /> 
    <!-- 配置获取连接等待超时的时间 --> 
    < property name = "maxwait" value = "${maxwait}" /> 
    <!-- 最小空闲连接数 --> 
    < property name = "minidle" value = "${minidle}" />  
    <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 --> 
    < property name = "timebetweenevictionrunsmillis" value ="${timebetweenevictionrunsmillis}" /> 
    <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 --> 
    < property name = "minevictableidletimemillis" value ="${minevictableidletimemillis}" />  
    < property name = "validationquery" value = "${validationquery}" />  
    < property name = "testwhileidle" value = "${testwhileidle}" />  
    < property name = "testonborrow" value = "${testonborrow}" />  
    < property name = "testonreturn" value = "${testonreturn}" />  
    < property name = "maxopenpreparedstatements" value ="${maxopenpreparedstatements}" /> 
    <!-- 打开 removeabandoned 功能 --> 
    < property name = "removeabandoned" value = "${removeabandoned}" /> 
    <!-- 1800 秒,也就是 30 分钟 --> 
    < property name = "removeabandonedtimeout" value ="${removeabandonedtimeout}" /> 
    <!-- 关闭 abanded 连接时输出错误日志 -->   
    < property name = "logabandoned" value = "${logabandoned}" /> 
 </ bean > 

dbconfig.properties

url: jdbc:mysql:// localhost :3306/ newm 
driverclassname: com.mysql.jdbc.driver 
username: root 
password: root 
filters: stat 
maxactive: 20 
initialsize: 1 
maxwait: 60000 
minidle: 10 
maxidle: 15 
timebetweenevictionrunsmillis: 60000 
minevictableidletimemillis: 300000 
validationquery: select 'x' 
testwhileidle: true 
testonborrow: false 
testonreturn: false 
maxopenpreparedstatements: 20 
removeabandoned: true 
removeabandonedtimeout: 1800 
logabandoned: true 

web.xml

<!-- 连接池 启用 web 监控统计功能  start--> 
 < filter > 
   < filter-name > druidwebstatfilter </ filter-name > 
   < filter-class > com.alibaba.druid.support.http.webstatfilter </ filter-class > 
   < init-param > 
     < param-name > exclusions </ param-name > 
     < param-value > *. js ,*. gif ,*. jpg ,*. png ,*. css ,*. ico ,/ druid /* </ param-value > 
   </ init-param > 
 </ filter > 
 < filter-mapping > 
   < filter-name > druidwebstatfilter </ filter-name > 
   < url-pattern > /* </ url-pattern > 
 </ filter-mapping > 
 < servlet > 
   < servlet-name > druidstatview </ servlet-name > 
   < servlet-class > com.alibaba.druid.support.http.statviewservlet </ servlet-class > 
 </ servlet > 
 < servlet-mapping > 
   < servlet-name > druidstatview </ servlet-name > 
   < url-pattern > / druid /* </ url-pattern > 
 </ servlet-mapping > 
 <!-- 连接池 启用 web 监控统计功能  end--> 

访问监控页面: http://ip:port/projectname/druid/index.html

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。