文档章节

Druid使用配置初步理解

chenhuaming
 chenhuaming
发布于 2016/10/08 15:09
字数 882
阅读 966
收藏 2

精选30+云产品,助力企业轻松上云!>>>

Druid是什么?

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

Druid已经在阿里巴巴部署了超过600个应用,经过一年多生产环境大规模部署的严苛考验。

同时Druid不仅仅是一个数据库连接池,它包括四个部分:
Druid是一个JDBC组件,它包括三个部分:

Druid可以做什么?

  • 替换DBCP和C3P0。Druid提供了一个高效、功能强大、可扩展性好的数据库连接池。
  • 可以监控数据库访问性能,Druid内置提供了一个功能强大的StatFilter插件,能够详细统计SQL的执行性能,这对于线上分析数据库访问性能有帮助。
  • 数据库密码加密。直接把数据库密码写在配置文件中,这是不好的行为,容易导致安全问题。DruidDruiver和DruidDataSource都支持PasswordCallback。
  • SQL执行日志,Druid提供了不同的LogFilter,能够支持Common-Logging、Log4j和JdkLog,你可以按需要选择相应的LogFilter,监控你应用的数据库访问情况。
  • 扩展JDBC,如果你要对JDBC层有编程的需求,可以通过Druid提供的Filter机制,很方便编写JDBC层的扩展插件。

在项目中使用Druid非常简单,只要修改下配置文件就可以了

 

当我们在javaWEB项目中使用到druid来作为我们的连接池的时候,一定不会忘了添加监控功能。

首先是过滤器filter的配置,在web.xml中添加如下配置

 

<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>

过滤器中的配置,是用来定义我们的监控选项,在以上的监控配置中,我们定义了一个简单的监控,并采用了大量的默认配置,如果你想使用更丰富的监控配置,可以在druid的github wiki上获取更多的选项,地址:druid Filter 配置

选项配置结束之后,就是我们监控界面的路径配置了,servlet配置我们将在哪里打开我们的监控页面,在web.xml中添加如下代码

 

<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>

以上配置中,我们将我们的网页监控路径放在了,项目路径下的 druid路径中,类似于 www.myroject.com/druid.

同样的,上面的配置只是一个简单的配置,更丰富的选项,需要您移步:druid servlet 配置

至此,一个简单的web项目就配好了监控的页面,但是大多数人在开发javaWEB项目中时都避免不了使用到各种框架和其他的技术,我将在后面的博文中陆续写出相应的配置方式。

spring配置

<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">  

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

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

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

     <property name="filters" value="stat" />  

     <property name="maxActive" value="20" />   

     <property name="initialSize" value="1" />  

      <property name="maxWait" value="60000" />  

 <property name="minIdle" value="1" /> 

 <property name="timeBetweenEvictionRunsMillis" value="3000" />  

<property name="minEvictableIdleTimeMillis" value="300000" /> 

 <property name="validationQuery" value="SELECT 'x'" />  

<property name="testWhileIdle" value="true" />  

<property name="testOnBorrow" value="false" />  

<property name="testOnReturn" value="false" />  

<property name="poolPreparedStatements" value="true" /> 

 <property name="maxPoolPreparedStatementPerConnectionSize" value="20" /> 

</bean>   

 


就可以了.
监控页面

上一篇: 分布式事务
下一篇: tomcat端口修改
chenhuaming
粉丝 1
博文 19
码字总数 6788
作品 0
广州
程序员
私信 提问
数据库连接每隔20天作用就会断掉,druid无法识别报错误

基础环境:mysql、spring-data-jpa、hibernate、tomcat、druid,datasource配置如下:

MR_TS
2019/05/24
423
2
诡异的druid链接池链接断开故障经验总结

背景 症状 排查 修复 背景 最近在陆续做机房升级相关工作,配合DBA对产线数据库链接方式做个调整,将原来直接链接读库的地址切换到统一的读负载均衡的代理 haproxy 上,方便机柜和服务器的搬...

王清培
2019/01/19
0
0
诡异的druid链接池链接断开故障经验总结

背景 症状 排查 修复 背景 最近在陆续做机房升级相关工作,配合DBA对产线数据库链接方式做个调整,将原来直接链接读库的地址切换到统一的读负载均衡的代理 haproxy 上,方便机柜和服务器的搬...

王清培
2019/01/19
0
0
带着萌新看springboot源码10(springboot+JdbcTemplate+druid)

  上一节把springboot和jdbcTemplate大概用法说了一下,以及大概看了一下源码,还说了加载sql文件时的原理。   这一节来看看自动注入JdbcTemplate的原理,顺便用一用Druid数据源(功能比...

osc_ikbuen62
2018/11/22
6
0
druid不支持OSGI

@wenshao 你好,想跟你请教个问题: druid怎么不支持一下OSGI? 我是在OSGI运行环境下使用druid的,虽然有工具可以对jar包进行转换,初步验证也能连接db查询数据,但由于druid 依赖的jconsol...

小珂
2016/03/04
735
4

没有更多内容

加载失败,请刷新页面

加载更多

我在哪里可以在线找到Android源代码? [关闭] - Where can I find Android source code online? [closed]

问题: Particularly, where can I browse the source code for any android source application(egthe contact application) ? 特别是,我在哪里可以浏览任何Android源应用程序(例如联系人......

javail
27分钟前
17
0
如何以常规格式打印日期? - How to print a date in a regular format?

问题: This is my code: 这是我的代码: import datetimetoday = datetime.date.today()print today This prints: 2008-11-22 which is exactly what I want. 打印: 2008-11-22这正是我......

fyin1314
57分钟前
17
0
动态规划:LC198.打家劫舍

题目描述: 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入...

曦鱼violet
今天
30
0
OSChina 周一乱弹 —— 南方水到底多深

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: Various Artists-用印度乐器演奏苏联国歌(洛天侬 remix) 手机党少年们想听歌,请...

小小编辑
今天
56
0
快递100云平台的安全措施--API限流

2、热点参数限流 注意: 若 entry 的时候传入了热点参数,那么 exit 的时候也一定要带上对应的参数(exit(count, args)),否则可能会有统计错误。 3、通过 ParamFlowRuleManager 的 loadRu...

bykk
今天
19
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部