druid连接池

近期一直报连接池连接的错误,主要就是那个什么last packet 多少ms以前。

所以就研究了下。

druid连接池和mysql的连接关系可以简单理解为下面的案例。

有10个接线员A和远程10个接口员B在通讯,如果不用连接池,那么每用一次就要拨号、建立链接、通话、挂断,非常浪费时间。所以如果10个接线员A提前就和B接通,然后一直不挂断,这样需要时只要喊话一下就行了,效率高,真正的基于TCP连接可以参考下载

但是这样会导致一个问题,如果B偷懒,偷偷的将电话挂断,而A不知道,再讲话就会出错了。

针对这种情况,druid提供了几种解决方案:

1、在连接时加入探测。

Xml代码  下载

  1. <property name="validationQuery" value="select 1"/>
  2. <property name="testWhileIdle" value="true"/>#空闲时检测
  3. <property name="testOnBorrow" value="true"/>#获取连接时检测
  4. <property name="testOnReturn" value="true"/>#放回连接池时检测

2、在空闲时检测链接。

Xml代码  下载

  1. <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
  2. <property name="timeBetweenEvictionRunsMillis" value="60"/>
  3. <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
  4. <property name="minEvictableIdleTimeMillis" value="300000"/>

注:每隔60毫秒检测一下,连接池在池中最小生存的时间是300秒。

3、druid连接池基本配置:

Xml代码  下载

  1. main.db.initialSize=10#初始化连接个数
  2. main.db.minIdle=5#如果10个连接被干掉了,起码起来5个
  3. main.db.maxActive=50#最多到50个
  4. main.db.maxWait=60000#连接超过60秒报超时异常,一般是网络问题或者服务器响应太慢。

4、完整的案例:

Xml代码  下载

  1. <!-- Druid 数据库源配置 -->
  2. <bean id="mainDataSource" class="com.alibaba.druid.pool.DruidDataSource"
  3. init-method="init" destroy-method="close">
  4. <!-- 基本属性 url、user、password -->
  5. <property name="url" value="${main.db.jdbcUrl}"/>
  6. <property name="username" value="${main.db.username}"/>
  7. <property name="password" value="${main.db.password}"/>
  8. <!-- 配置初始化大小、最小、最大 -->
  9. <property name="initialSize" value="${main.db.initialSize}"/>
  10. <property name="minIdle" value="${main.db.minIdle}"/>
  11. <property name="maxActive" value="${main.db.maxActive}"/>
  12. <!-- 配置获取连接等待超时的时间 -->
  13. <property name="maxWait" value="${main.db.maxWait}"/>
  14. <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
  15. <property name="timeBetweenEvictionRunsMillis" value="50"/>
  16. <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
  17. <property name="minEvictableIdleTimeMillis" value="300000"/>
  18. <property name="validationQuery" value="select 1"/>
  19. <property name="testWhileIdle" value="true"/>
  20. <property name="testOnBorrow" value="true"/>
  21. <property name="testOnReturn" value="true"/>
  22. <!-- 超过时间限制是否回收 -->
  23. <property name="removeAbandoned" value="true" />
  24. <!-- 超时时间;单位为秒。180秒=3分钟 -->
  25. <property name="removeAbandonedTimeout" value="500000000" />
  26. <!-- 关闭abanded连接时输出错误日志 -->
  27. <property name="logAbandoned" value="true" />
  28. <!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
  29. <!--property name="poolPreparedStatements" value="true"/>
  30. <property name="maxPoolPreparedStatementPerConnectionSize"
  31. value="20"/-->
  32. <!-- 配置监控统计拦截的filters。状态统计:stat,日常记录:slf4j -->
  33. <property name="filters" value="stat,slf4j"/>
  34. </bean>

4.2、druid官方下载 :

Java代码

  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
  2. <property name="url" value="${jdbc_url}" />
  3. <property name="username" value="${jdbc_user}" />
  4. <property name="password" value="${jdbc_password}" />
  5. <property name="filters" value="stat" />
  6. <property name="maxActive" value="20" />
  7. <property name="initialSize" value="1" />
  8. <property name="maxWait" value="60000" />
  9. <property name="minIdle" value="1" />
  10. <property name="timeBetweenEvictionRunsMillis" value="60000" />
  11. <property name="minEvictableIdleTimeMillis" value="300000" />
  12. <property name="validationQuery" value="SELECT ‘x‘" />
  13. <property name="testWhileIdle" value="true" />
  14. <property name="testOnBorrow" value="false" />
  15. <property name="testOnReturn" value="false" />
  16. <property name="poolPreparedStatements" value="true" />
  17. <property name="maxPoolPreparedStatementPerConnectionSize" value="50" />
  18. </bean>

5、修改mysql超时时间。

mysql超时时间分为time_out和interactive_timeout,ubuntu修改mysql配置:/etc/mysql/my.cnf

在[mysqld]添加如下设置:下载

Shell代码

  1. wait_timeout = 86400
  2. interactive_timeout = 86400

设置完成后,用:show variables like ‘%timeout%‘ 查看有没有设置成功,注意到单引号。

设置完成后,重启mysql服务:sudo service mysql restart.

时间: 2024-10-19 11:09:09

druid连接池的相关文章

SpringMVC+Spring+Mybatis整合,使用druid连接池,声明式事务,maven配置

一直对springmvc和mybatis挺怀念的,最近想自己再搭建下框架,然后写点什么. 暂时没有整合缓存,druid也没有做ip地址的过滤.Spring的AOP简单配置了下,也还没具体弄,不知道能不能用,log也不知道能不能用,`(*∩_∩*)′哈哈,有点不负责任...... 直接上代码: 使用的eclipse和eclipse自带的maven,参考了网上的资料,有些代码是拷贝的,不过都自己测试过了.嗯,可以跑起来... 先上项目结构: 新建maven项目,选择web,然后配置pom: <pro

使用druid连接池的超时回收机制排查连接泄露问题

在工程中使用了druid连接池,运行一段时间后系统出现异常: Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60009, active 50 at org.springfr

Druid连接池-阿里巴巴开源JDBC组件

Druid在连接池领域里可以说是比较火的,是阿里巴巴开源的JDBC连接池.监控组件,下面就简单介绍它一下. 它包括三部分:  DruidDriver 代理Driver,能够提供基于Filter-Chain模式的插件体系. DruidDataSource 高效可管理的数据库连接池. SQLParser . 功能:     .  可以监控数据库访问性能,Druid内置提供了一个功能强大的StatFilter插件,能够详细统计SQL的执行性能,这对于线上分析数据库访问性能有帮助.     .  替换D

spring 4 + jpa(hibernate 3/4) + spring mvc 多数据源配置(二)+Druid连接池

接上一个博文(http://www.loveweir.com/html/18.html),没有数据库连接池,纯粹用jpa的官方链接. 所以这次要加上连接池本文用Druid连接池来实现多数据源的配置. persistence.xml 这个文件可以省略了,全部配置在applicationContext.xml 里面: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www

Druid连接池及监控在spring中的配置

Druid连接池及监控在Spring配置如下: [html] view plaincopy <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> <!-- 基本属性 url.user.password --> <property 

使用druid连接池,配置sql防火墙发现的sql注入问题

最近在使用druid连接池,同时也配置了web和spring的关联监控,检测到select * from tables param like #{param1} "%"的语句被拦截了.做个笔记. 解决方法有两种: 一. select * from tables param like concat(${param1},"%"). 二.传入 参数的时候动态拼接 param1=param1+"%"; select * from tables param

SpringBoot配置MySql数据库和Druid连接池

1.pom文件增加相关依赖,我这里因为上面引入了父pom,所以不需要在当前pom文件下加版本 <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifact

Spring Boot2.x 的Druid连接池配置[附带监控]

父依赖[Spring Boot 2.1.x版本] <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.1.RELEASE</version> </parent> 主要依赖[3个] <!--Druid 连接池与Spring B

springboot+druid连接池及监控配置

1. 问题描述 阿里巴巴的数据库连接池Druid在效率与稳定性都很高,被很多开发团队使用,并且自带的Druid监控也很好用,本章简单介绍下springboot+druid配置连接池及监控. 2. 解决方案 2.1 pom.xml springboot 已经有druid的starter,但是好像有点问题,不知道为什么没拿到jar包,有可能是网络问题,还是使用了原生的druid gav. <dependency> <groupId>com.alibaba</groupId>