连接池自动重连(转自王晓东)

news/2024/5/19 0:21:17 标签: 数据库, mysql, jdbc, date, 文档, 测试

 项目使用的连接池是Proxool,功能相当强大,不过今天遇到一个问题,如果连接池在运行当中,出现网络或者数据库故障而无法连接到数据库,在恢复正常以后,由于连接是在连接池中持久保存的,会出现连接仍然不可用的情况,这时连接池里的连接实际上都是坏连接,怎么让连接池可以自动重连清除这些坏连接呢?

    在网上搜了半天,有不少人问这个问题,但不是没人回答就是讲了一堆如何配置,没说怎么才能自动重连接。经过查官方文档的配置参数和测试,发现其实只要配置了test-before-use 参数,即每次取出连接都检查连接是否可用,就可以做到让连接池实现在故障恢复后自动重连接。实例配置文件如下:(红色的部分)

<proxool>
    <alias>pool</alias>
    <driver-url> jdbc:mysql://localhost:3306/cds </driver-url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <driver-properties>
        <property name="user" value="vcom" />
        <property name="password" value="vcom" />
        <property name="autoReconnect" value="true" />
    </driver-properties>
    <minimum-connection-count>1</minimum-connection-count>
    <maximum-connection-count>8</maximum-connection-count>
    <prototype-count>1</prototype-count>
    <test-before-use>true</test-before-use>
    <house-keeping-sleep-time>60000</house-keeping-sleep-time>  
    <house-keeping-test-sql>select CURRENT_DATE from dual</house-keeping-test-sql>
</proxool>

 

需要注意一点,对于Mysql数据库还必须在连接参数里加上autoReconnect=true 参数,否则即使打开了test-before-use 参数,仍然不能重连接!


http://www.niftyadmin.cn/n/873935.html

相关文章

onenote日历模板_用微软 OneNote 做简洁的手账笔记

听说手账是日本人发明的&#xff0c;在日本&#xff0c;大部分人都会随身带着一个被称为“手账”的笔记本&#xff0c;随时随地掏出来翻翻看&#xff0c;或者在上面记些什么。手账不仅能提醒自己记着家人、朋友的生日和约会&#xff0c;还能安排每天的工作。做手账&#xff0c;…

spring学习中常用到的工厂,抽象工厂学习

工厂模式有简单工厂模式,工厂方法模式和抽象工厂模式几种形态。其中简单工厂模式和工厂方法模式已经在前面作过介绍。在这里&#xff0c;我们来介绍抽象工厂模式。   抽象工厂模式是所有形态的工厂模式中最为抽象和最具广泛性的一种形态。   抽象工厂模式的定义  抽象工厂…

按钮隐藏后还可用吗_浏览器隐藏功能,一键管理你的私藏网站!

本文经授权转自「太平洋电脑网」如果几个标签同属于一个网站&#xff0c;将它们分组批量化管理&#xff0c;可以大幅提升浏览效率&#xff0c;这就是Microsoft Edge(Chromium内核)中一项隐藏功能——标签分组Tab Groups。Edge浏览器隐藏的标签分组功能标签分组Tab Groups是Micr…

解决JSP开发Web程序中的中文问题

中文出现?号&#xff0c;即常说的乱码。原因其实很简单&#xff0c;因为大家大多用的是tomcat作为容器&#xff0c;而tomcat服务器的默认编码为 iso-8859-1(西欧字符)。就是因为iso-8859-1(西欧字符)编码造成了我们经常看到&#xff1f;号。方法一&#xff1a;最简单也是用的最…

web开发java中文编码问题

web开发java中文编码问题 关于JSP页面中的pageEncoding和contentType两种属性的区别&#xff1a; pageEncoding是jsp文件本身的编码 contentType的charset是指服务器发送给客户端时的内容编码 JSP要经过两次的“编码”&#xff0c;第一阶段会用pageEncoding&#xff0c;第二阶段…

Cookie域

server端&#xff1a; Java代码 Set-Cookie:domain.test.com key000001 Set-Cookie:domain.test.com path/lsd keytest.com/lsd Set-Cookie:domain.test.com path/lsd/ak47 keytest.com/lsd-ak47 Set-Cookie:domain.test.com path/lsd/lsd keytest.com/lsd-lsd Set-C…

python写前端被嘲讽_python之路-----前端之html协议一

一.概述1.1 什么是html语句&#xff1f;超文本标记语言(Hypertext Markup Language&#xff0c;HTML)通过标签语言来标记要显示的网页中的各个部分。一套规则&#xff0c;浏览器认识的规则浏览器按顺序渲染网页文件&#xff0c;然后根据标记符解释和显示内容。但需要注意的是&a…

必须面对

人生是每个人都无法逃避、必须面对的东西&#xff0c;有的时候人生很苦涩&#xff0c;让人不知道应该如何面对&#xff0c;我也经常不知道应该如何面对&#xff0c;也经常选择逃避&#xff0c;也时不时觉得苦涩&#xff0c;但我想&#xff0c;人生的痛苦其实并非来自于贫穷、挫…