一、问题

获取MySQL连接,8小时内无请求自动断开连接。

二、解决

2.1 分析

MySQL服务器默认的"wait_timeout"是28800秒即8小时,意味着如果一个连接的空闲时间超过8小时,MySQL将自动断开连接,而连接池却认为该连接还是有效的,当应用申请使用该连接时,就会导致报错

2.2 修改MySQL配置

通过配置文件修改:my.cnf

  1. wait_timeout=31536000
  2. interactive_timeout=31536000

通过命令修改

2.3 c3p0

方案一:减少连接池内连接的生存周期

方案二:定期使用连接池内的连接

Spring配置文件

  1. <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
  2. <!-- 方案一 -->
  3. <property name="maxIdleTime"value="1800"/>
  4. <!-- 方案二 -->
  5. <property name="preferredTestQuery" value="SELECT 1"/>
  6. <property name="idleConnectionTestPeriod" value="18000"/>
  7. <property name="testConnectionOnCheckout" value="true"/>
  8. <!--other properties -->
  9. </bean>

2.4 dbcp

  1. <data-sources>
  2. <data-source key="org.apache.struts.action.DATA_SOURCE" type="org.apache.commons.dbcp.BasicDataSource">
  3. <set-property property="driverClassName" value="com.mysql.jdbc.Driver" />
  4. <set-property property="description" value="wjjg" />
  5. <set-property property="url" value="jdbc:mysql://localhost/start?useUnicode=true&characterEncoding=GB2312" />
  6. <set-property property="password" value="12345678" />
  7. <set-property property="username" value="wjjg" />
  8. <set-property property="maxActive" value="10" />
  9. <set-property property="maxIdle" value="60000" />
  10. <set-property property="maxWait" value="60000" />
  11. <set-property property="defaultAutoCommit" value="true" />
  12. <set-property property="defaultReadOnly" value="false" />
  13. <set-property property="testOnBorrow" value="true"/>
  14. <set-property property="validationQuery" value="select 1"/>
  15. </data-source>

说明:

  1. testOnBorrow的意思是从数据库连接池中取得连接时,对其的有效性进行检查。
  2. validationQuery 是用来检查的SQL语句,“select 1”执行较快,是一个不错的检测语句。

三、扩展

3.1 c3p0配置文件

  1. <default-config>
  2.   <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
  3.   <property name="acquireIncrement">3</property>
  4.   <!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
  5.   <property name="acquireRetryAttempts">30</property>
  6.   <!--两次连接中间隔时间,单位毫秒。Default: 1000 -->
  7.   <property name="acquireRetryDelay">1000</property>
  8.   <!--连接关闭时默认将所有未提交的操作回滚。Default: false -->
  9.   <property name="autoCommitOnClose">false</property>
  10.   <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么
  11.   属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试
  12.   使用。Default: null-->
  13.   <property name="automaticTestTable">Test</property>
  14.   <!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效
  15.   保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试
  16.   获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->
  17.   <property name="breakAfterAcquireFailure">false</property>
  18.   <!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出
  19.   SQLException,如设为0则无限期等待。单位毫秒。Default: 0 -->
  20.   <property name="checkoutTimeout">100</property>
  21.   <!--通过实现ConnectionTester或QueryConnectionTester的类来测试连接。类名需制定全路径。
  22.   Default: com.mchange.v2.c3p0.impl.DefaultConnectionTester-->
  23.   <property name="connectionTesterClassName"></property>
  24.   <!--指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可
  25.   Default: null-->
  26.   <property name="factoryClassLocation">null</property>
  27.   <!--Strongly disrecommended. Setting this to true may lead to subtle and bizarre bugs.
  28.   (文档原文)作者强烈建议不使用的一个属性-->
  29.   <property name="forceIgnoreUnresolvedTransactions">false</property>
  30.   <!--每60秒检查所有连接池中的空闲连接。Default: 0 -->
  31.   <property name="idleConnectionTestPeriod">60</property>
  32.   <!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->
  33.   <property name="initialPoolSize">3</property>
  34.   <!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
  35.   <property name="maxIdleTime">60</property>
  36.   <!--连接池中保留的最大连接数。Default: 15 -->
  37.   <property name="maxPoolSize">15</property>
  38.   <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements
  39.   属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。
  40.   如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
  41.   <property name="maxStatements">100</property>
  42.   <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->
  43.   <property name="maxStatementsPerConnection"></property>
  44.   <!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能
  45.   通过多线程实现多个操作同时被执行。Default: 3-->
  46.   <property name="numHelperThreads">3</property>
  47.   <!--当用户调用getConnection()时使root用户成为去获取连接的用户。主要用于连接池连接非c3p0
  48.   的数据源时。Default: null-->
  49.   <property name="overrideDefaultUser">root</property>
  50.   <!--与overrideDefaultUser参数对应使用的一个参数。Default: null-->
  51.   <property name="overrideDefaultPassword">password</property>
  52.   <!--密码。Default: null-->
  53.   <property name="password"></property>
  54.   <!--定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:
  55.   测试的表必须在初始数据源的时候就存在。Default: null-->
  56.   <property name="preferredTestQuery">select id from test where id=1</property>
  57.   <!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->
  58.   <property name="propertyCycle">300</property>
  59.   <!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的
  60.   时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable
  61.   等方法来提升连接测试的性能。Default: false -->
  62.   <property name="testConnectionOnCheckout">false</property>
  63.   <!--如果设为true那么在取得连接的同时将校验连接的有效性。Default: false -->
  64.   <property name="testConnectionOnCheckin">true</property>
  65.   <!--用户名。Default: null-->
  66.   <property name="user">root</property>
  67.   在Hibernate(spring管理)中的配置:
  68.   <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
  69.   <property name="driverClass"><value>oracle.jdbc.driver.OracleDriver</value></property>
  70.   <property name="jdbcUrl"><value>jdbc:oracle:thin:@localhost:1521:Test</value></property>
  71.   <property name="user"><value>Kay</value></property>
  72.   <property name="password"><value>root</value></property>
  73.   <!--连接池中保留的最小连接数。-->
  74.   <property name="minPoolSize" value="10" />
  75.   <!--连接池中保留的最大连接数。Default: 15 -->
  76.   <property name="maxPoolSize" value="100" />
  77.   <!--最大空闲时间,1800秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
  78.   <property name="maxIdleTime" value="1800" />
  79.   <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
  80.   <property name="acquireIncrement" value="3" />
  81.   <property name="maxStatements" value="1000" />
  82.   <property name="initialPoolSize" value="10" />
  83.   <!--每60秒检查所有连接池中的空闲连接。Default: 0 -->
  84.   <property name="idleConnectionTestPeriod" value="60" />
  85.   <!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
  86.   <property name="acquireRetryAttempts" value="30" />
  87.   <property name="breakAfterAcquireFailure" value="true" />
  88.   <property name="testConnectionOnCheckout" value="false" />
  89.   </bean>
  90.   ###########################
  91.   ### C3P0 Connection Pool###
  92.   ###########################
  93.   #hibernate.c3p0.max_size 2
  94.   #hibernate.c3p0.min_size 2
  95.   #hibernate.c3p0.timeout 5000
  96.   #hibernate.c3p0.max_statements 100
  97.   #hibernate.c3p0.idle_test_period 3000
  98.   #hibernate.c3p0.acquire_increment 2
  99.   #hibernate.c3p0.validate false
  100.   在hibernate.cfg.xml文件里面加入如下的配置:
  101.   <!-- 最大连接数 -->
  102.   <property name="hibernate.c3p0.max_size">20</property>
  103.   <!-- 最小连接数 -->
  104.   <property name="hibernate.c3p0.min_size">5</property>
  105.   <!-- 获得连接的超时时间,如果超过这个时间,会抛出异常,单位毫秒 -->
  106.   <property name="hibernate.c3p0.timeout">120</property>
  107.   <!-- 最大的PreparedStatement的数量 -->
  108.   <property name="hibernate.c3p0.max_statements">100</property>
  109.   <!-- 每隔120秒检查连接池里的空闲连接 ,单位是秒-->
  110.   <property name="hibernate.c3p0.idle_test_period">120</property>
  111.   <!-- 当连接池里面的连接用完的时候,C3P0一下获取的新的连接数 -->
  112.   <property name="hibernate.c3p0.acquire_increment">2</property>
  113.   <!-- 每次都验证连接是否可用 -->
  114.   <property name="hibernate.c3p0.validate">true</property>

四、参考

使用c3p0与DBCP连接池,造成的MySql 8小时问题解决方案

MySQL8小时问题的更多相关文章

  1. c3p0数据源的使用初步及Mysql8小时问题解决

    原文:http://blog.csdn.net/xby1993/article/details/23707775 c3p0号称是java界最好的数据池. c3p0的配置方式分为三种,分别是 1.set ...

  2. 解决mysql8小时无连接自动断掉机制

    windows下打开my.ini,增加: interactive_timeout=28800000 wait_timeout=28800000 MySQL是一个小型关系型数据库管理系统,由于MySQL ...

  3. hibernate+mysql 8小时问题

    在生产环境中使用了 自带的连接池 结果 遇到 mysql8小时问题 然后 采用了 c3p0 连接池 hibernate 版本 4.3.6 c3p0版本 0.9.5-pre10 ps:hibernate ...

  4. 使用c3p0与DBCP连接池,造成的MySql 8小时问题解决方案

    转自:http://blog.csdn.net/wangfayinn/article/details/24623575 c3p0数据库连接池mysql8小时 目录(?)[-] 基本问题解决 项目环境 ...

  5. MySql 8小时解决方案:proxool连接池

    最近做的项目用的mysql数据库,前天挂在服务器上,昨天早晨上班一来,同事就说API数据接口访问不了了,我马上mstsc登陆服务器看,报错了.马上重启tomcat,结果还能正常运行,当时没管,今天过来 ...

  6. mysql交互式连接&非交互式连接

    交互式操作:通俗的说,就是你在你的本机上打开mysql的客户端,就是那个黑窗口,在黑窗口下进行各种sql操作,当然走的肯定是tcp协议. 非交互式操作:就是你在你的项目中进行程序调用.比如一边是tom ...

  7. c3p0三种配置方式(automaticTestTable)

    c3p0的配置方式分为三种,分别是http://my.oschina.net/lyzg/blog/551331.setters一个个地设置各个配置项2.类路径下提供一个c3p0.properties文 ...

  8. c3p0配置详解

    数据库连接池C3P0框架是个非常优异的开源jar,高性能的管理着数据源,这里只讨论程序本身负责数据源,不讨论容器管理. 一.实现方式: C3P0有三种方式实现: 1.自己动手写代码,实现数据源 例如: ...

  9. c3p0 --2

    c3p0号称是java界最好的数据池. c3p0的配置方式分为三种,分别是 1.setters一个个地设置各个配置项 2.类路径下提供一个c3p0.properties文件 3.类路径下提供一个c3p ...

随机推荐

  1. glusterfs架构和原理

    分布式存储已经研究很多年,但直到近年来,伴随着谷歌.亚马逊和阿里等互联网公司云计算和大数据应用的兴起,它才大规模应用到工程实践中.如谷歌的分布式文件系统GFS.分布式表格系统google Bigtab ...

  2. 手把手教你打造一个纯CSS图标库

    来,干了这碗安利 写这篇文章的目的其实就是为了安利一下我的图标库:iconoo,所以,开门见山,star吧少年少妇们!(这样的我是不是应该要加个github互粉的团伙了?) 主题说完了,下面进入正题. ...

  3. 原生js实现架子鼓特效

    这是代码完成的效果,按下abcd会出现对应的架子鼓音乐的效果. 简单的介绍下代码思路,html和css部分就不多说了. 重要的是js部分. 大致是这样的, 首先获取到所有的按钮为一个数组,然后遍历整个 ...

  4. java Web开发实现手机拍照上传到服务器

    第一步: 搭环境,基本jdk 1.6+apache tomcat6.0+myeclipse2014 1.我们要清楚自己的jdk版本.因为我们Apache Tomcat配置的成功的前提是版本相对应. 安 ...

  5. Day10 - JS 实现 Checkbox 中按住 Shift 的多选功能

    Day10 - JS 实现 Checkbox 中按住 Shift 的多选功能 作者:liyuechun 简介:JavaScript30 是 Wes Bos 推出的一个 30 天挑战.项目免费提供了 3 ...

  6. 在 MarkDown 中添加表格(例如:在 CSDN 中添加表格)

    内容 一.使用 Markdown 创建表格(例如:在 CSDN 中创建表格) 1. 表格格式 对齐方式 -: 设置内容和标题栏居右对齐: :- 设置内容和标题栏居左对齐: :-: 设置内容和标题栏居中 ...

  7. Java Web项目与Java项目的区别

    一.以下是我对Java Web项目和Java项目这两者的理解以及区别: 1.Java Web项目是基于Java EE类的:而Java项目是基于Java应用程序的. 2.Java Web项目是网页的编码 ...

  8. Blazor组件自做九: 用20行代码实现文件上传,浏览目录功能 (3)

    接上篇 Blazor组件自做九: 用20行代码实现文件上传,浏览目录功能 (2) 7. 使用配置文件指定监听地址 打开 appsettings.json 文件,加入一行 "UseUrls&q ...

  9. 【代码大全2 学习笔记】ADT 抽象与封装

    ADT abstract data type 抽象数据类型 要理解面向对象编程,就要先理解ADT这个概念.不懂ADT的程序员开发出来的类只是名义上的"类"而已--只是单纯的把一些相 ...

  10. 在keil中加入DSP库并且使用arm_math.h

    如果不开启硬件FPU,代码设置和编译控制建议二选一,否则会出现宏定义重复定义的报错