druid配置
来源:互联网 发布:淘宝死人衣服是真是假 编辑:程序博客网 时间:2024/05/19 04:07
1、 配置
和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:ocnautousername 连接数据库的用户名password 连接数据库的密码。如果你不希望密码直接写在配置文件中,
可以使用ConfigFilter。详细看这里:
https://github.com/alibaba/druid/wiki/%E4%BD%BF%E7%94%A8ConfigFilterdriverClassName根据url自动识别这一项可配可不配,如果不配置druid会根据url自动识别dbType,
然后选择相应的driverClassNameinitialSize0初始化时建立物理连接的个数。初始化发生在显示调用init方法,
或者第一次getConnection时maxActive8最大连接池数量maxIdle8已经不再使用,配置了也没效果minIdle 最小连接池数量maxWait 获取连接时最大等待时间,单位毫秒。配置了maxWait之后,
缺省启用公平锁,并发效率会有所下降,
如果需要可以通过配置useUnfairLock属性为true使用非公平锁。poolPreparedStatementsfalse是否缓存preparedStatement,也就是PSCache。
PSCache对支持游标的数据库性能提升巨大,比如说oracle。
在mysql5.5以下的版本中没有PSCache功能,建议关闭掉。
5.5及以上版本有PSCache,建议开启。maxOpenPreparedStatements-1要启用PSCache,必须配置大于0,当大于0时,
poolPreparedStatements自动触发修改为true。
在Druid中,不会存在Oracle下PSCache占用内存过多的问题,
可以把这个数值配置大一些,比如说100validationQuery 用来检测连接是否有效的sql,要求是一个查询语句。
如果validationQuery为null,testOnBorrow、testOnReturn、
testWhileIdle都不会其作用。testOnBorrowtrue申请连接时执行validationQuery检测连接是否有效,
做了这个配置会降低性能。testOnReturnfalse归还连接时执行validationQuery检测连接是否有效,
做了这个配置会降低性能testWhileIdlefalse建议配置为true,不影响性能,并且保证安全性。
申请连接的时候检测,如果空闲时间大于
timeBetweenEvictionRunsMillis,
执行validationQuery检测连接是否有效。timeBetweenEvictionRunsMillis 有两个含义:
1) Destroy线程会检测连接的间隔时间
2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明numTestsPerEvictionRun 不再使用,一个DruidDataSource只支持一个EvictionRunminEvictableIdleTimeMillis connectionInitSqls 物理连接初始化的时候执行的sqlexceptionSorter根据dbType自动识别当数据库抛出一些不可恢复的异常时,抛弃连接filters 属性类型是字符串,通过别名的方式配置扩展插件,
常用的插件有:
监控统计用的filter:stat
日志用的filter:log4j
防御sql注入的filter:wallproxyFilters 类型是List<com.alibaba.druid.filter.Filter>,
如果同时配置了filters和proxyFilters,
是组合关系,并非替换关系
配置项中指定了各个参数后,在连接池内部是这么使用这些参数的。数据库连接池在初始化的时候会创建initialSize个连接,当有数据库操作时,会从池中取出一个连接。如果当前池中正在使用的连接数等于maxActive,则会等待一段时间,等待其他操作释放掉某一个连接,如果这个等待时间超过了maxWait,则会报错;如果当前正在使用的连接数没有达到maxActive,则判断当前是否空闲连接,如果有则直接使用空闲连接,如果没有则新建立一个连接。在连接使用完毕后,不是将其物理连接关闭,而是将其放入池中等待其他操作复用。
同时连接池内部有机制判断,如果当前的总的连接数少于miniIdle,则会建立新的空闲连接,以保证连接数得到miniIdle。如果当前连接池中某个连接在空闲了timeBetweenEvictionRunsMillis时间后任然没有使用,则被物理性的关闭掉。有些数据库连接的时候有超时限制(mysql连接在8小时后断开),或者由于网络中断等原因,连接池的连接会出现失效的情况,这时候设置一个testWhileIdle参数为true,可以保证连接池内部定时检测连接的可用性,不可用的连接会被抛弃或者重建,最大情况的保证从连接池中得到的Connection对象是可用的。当然,为了保证绝对的可用性,你也可以使用testOnBorrow为true(即在获取Connection对象时检测其可用性),不过这样会影响性能。
2、监控
1
2
3
4
5
6
7
8
<
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
>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
function
showTime() {
var
myDate =
new
Date();
var
timeStr =
''
;
timeStr += myDate.getFullYear()+
'-'
;
//获取完整的年份(4位,1970-????)
timeStr += myDate.getMonth()+
'-'
;
//获取当前月份(0-11,0代表1月)
timeStr += myDate.getDate() +
' '
;
//获取当前日(1-31)
timeStr += myDate.getHours()+
':'
;
//获取当前小时数(0-23)
timeStr += myDate.getMinutes()+
':'
;
//获取当前分钟数(0-59)
timeStr += myDate.getSeconds();
//获取当前秒数(0-59)
return
timeStr
}
$(document).ready(
function
() {
function
loadDBTestMessage() {
$.get(
'servlet/MysqlTestServlet'
,
function
(data) {
if
(
typeof
(data) !=
'object'
) {
data = eval(
'('
+ data +
')'
);
}
var
html =
'['
+showTime()+
']'
;
html +=
'创建:'
+ data[
'createResult'
];
html +=
'插入:'
+ data[
'insertResult'
];
html +=
'销毁:'
+ data[
'dropResult'
];
html +=
$(
'#message'
).html(html);
});
}
setInterval(
function
() {
loadDBTestMessage();
}, 10000);
});
0 0
- druid配置
- druid配置
- druid配置
- druid配置
- druid配置
- Druid 配置
- druid配置
- druid配置
- Druid配置
- Druid 配置
- Druid 配置
- druid连接池配置Druid
- alibaba druid 的配置
- druid的配置。
- druid数据源配置
- Druid数据源的配置
- Druid数据源的配置
- druid连接池配置
- lxml安装遇到的问题
- 第四章:使用DML语句更改数据
- 谈谈SDN保障下的双十一
- MySQL简介、安装、函数接口和Linux C\C++操作MySQL实例详解
- 关于UIImagePickerController
- druid配置
- 关于float和double类型数据的输入输出
- jQuery-Mobile学习(页面)
- MyBatis_SqlMapConfig.xml初始
- C++11新特性应用--让你的程序更高效(右值引用避免深拷贝)
- Xcode 7 进行 http 请求时, 需要添加的字段
- RESideMeue使用观后感
- The entitlements specified in your application’s Code Signing Entitlements file do not match those s
- 网页布局相关知识点整理