简单的生产数据库重连策略优化

简单的druid生产数据库重连策略优化

1. 需求

我们生产环境有一次在大量请求拥堵后,好多数据库操作都超时了,在此之后数据库的连接池不能正常的获取数据库连接了,我们确认了数据库服务是没有问题的,那么就是连接池的配置有问题,所以需要优化连接池的配置信息,我们使用的是druid连接池,优化后服务便不会出现之前连接池获取不到连接情况,此处记录一下方便后续使用方便。

2. 具体优化配置

2.1 修改内容

我们的数据源是多数据源,从配置文件中读取,使用java代码实现,此处就不多赘述了,此处主要修改的breakAfterAcquireFailure这个参数。druidDataSource.setBreakAfterAcquireFailure(boolean flag)其具体参数作用如下所示:

  • 当设置为 true 时,如果获取连接失败(例如数据库服务不可用),Druid 连接池将进入“断开”状态。一旦进入该状态,后续的连接请求都会立即失败,直到连接池被重置或重启。

  • 当设置为 false 时,即使获取连接失败,连接池也不会进入“断开”状态,而是会继续尝试获取新的连接。

我们还添加了testOnBorrow参数设置,其具体作用如下:

  • 当设置为 true 时,在从连接池中借用连接之前,会先测试连接的有效性。如果连接无效,则会从连接池中移除并尝试获取新的有效连接。
  • 这种配置可以确保每次获取到的连接都是有效的,避免了使用失效连接导致的问题。

2.2 修改前后对比

修改前配置:setBreakAfterAcquireFailure(true):

  • 优点: 在某些情况下可以快速失败,避免浪费资源在无效的连接尝试上。
  • 缺点: 一旦连接池进入“断开”状态,除非手动重置或重启,否则无法恢复。这会导致在数据库服务短暂不可用后,应用无法自动恢复连接。

修改后配置:setBreakAfterAcquireFailure(false) + setTestOnBorrow(true):

  • 优点: 即使多次连接失败,连接池也不会进入“断开”状态,而是继续尝试获取新连接。同时,setTestOnBorrow(true) 确保每次获取到的连接都是有效的,从而提高了系统的健壮性和自愈能力。
  • 缺点: 可能会增加一些性能开销,因为每次借用连接前都需要进行有效性测试。

修改后具体代码如下:

/*** 动态数据源配置* @return DataSource 动态数据源*/
@Primary
@Bean
public DataSource multipleDataSource() {// 从获取动态数据源配置信息List<BusinessModuleType.Module> moduleList = businessModuleType.getModules();DynamicDataSource dynamicDataSource = DynamicDataSource.getInstance();Map<Object, Object> targetDataSources = new HashMap<>(BaseCacheProperties.DEFAULT_MAP_SIZE);moduleList.forEach(module -> {DruidDataSource moduleDataSource = new DruidDataSource();// 设置密码用户错误重连次数moduleDataSource.setConnectionErrorRetryAttempts(BaseCacheProperties.ERROR_RETRY_ATTEMPTS);// 数据库连接池连接失败重连配置moduleDataSource.setBreakAfterAcquireFailure(false);moduleDataSource.setTestOnBorrow(true);moduleDataSource.setDriverClassName(module.getClassName());moduleDataSource.setUrl(module.getUrl());moduleDataSource.setUsername(module.getUsername());moduleDataSource.setPassword(module.getPassword());moduleDataSource.setInitialSize(module.getInitialSize());moduleDataSource.setMinIdle(module.getMinSize());moduleDataSource.setMaxActive(module.getMaxSize());moduleDataSource.setMaxWait(module.getWaitTime());moduleDataSource.setTimeBetweenEvictionRunsMillis(module.getTimeBetweenEvictionRunsMillis());moduleDataSource.setMinEvictableIdleTimeMillis(module.getMinEvictableIdleTimeMillis());moduleDataSource.setValidationQuery(module.getValidation());if (BaseCacheProperties.DEFAULT_FLAG.equals(module.getName())) {targetDataSources.put(module.getDb(), dataSource);} else {targetDataSources.put(module.getDb(), moduleDataSource);}});dynamicDataSource.setTargetDataSources(targetDataSources);dynamicDataSource.setDefaultTargetDataSource(dataSource);return dynamicDataSource;
}

2.3 总结

改后的配置 (setBreakAfterAcquireFailure(false) 和 setTestOnBorrow(true)) 更加健壮,能够在数据库服务短暂不可用后自动恢复连接,而不会导致连接池进入“断开”状态。这种配置适合大多数生产环境,因为它提供了更好的容错能力和自愈能力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/65910.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大模型的prompt的应用二

下面总结一些在工作中比较实用的prompt应用。还可以到以下网站参考更多的prompt AI Prompts - WayToAGI 举个例子&#xff0c;让大模型写一份周报 # 角色:智能周报编写助手 ## 背景: 需要根据产品经理提供的简要周报框架,补充完整的周报内容。 ## 注意事项: 言简意赅,重点突…

期权懂|期权都有哪些存在的风险因素?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 期权都有哪些存在的风险因素&#xff1f; 一、市场价格波动风险 期权的价格受到多种因素的影响&#xff0c;包括标的资产价格、市场利率、波动率等。 这些因素的变化可能导致期…

2025跨年倒计时

<!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>2025年跨年倒计时</title><style>/* 页…

多模态论文笔记——Coca

大家好&#xff0c;这里是好评笔记&#xff0c;公主号&#xff1a;Goodnote&#xff0c;专栏文章私信限时Free。本文详细介绍多模态模型Coca&#xff0c;在DALLE 3中使用其作为captioner基准模型的原因和优势。 文章目录 ALBEF论文模型结构组成训练目标 CoCa​论文模型结构CoCa…

大型模型推理加速入门

一 推理加速基础 1. 了解基本概念与术语 首先需要了解关于大模型的一些基本的历史发展&#xff0c;概念和术语&#xff0c;不需要全部看懂&#xff0c;只需要掌握大概情况&#xff0c;可以通过下面这篇文章进行&#xff1a; 大模型入门基本概念&#xff0c;术语 2. 了解Tra…

python实现自动登录12306抢票 -- selenium

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 python实现自动登录12306抢票 -- selenium 前言其实网上也出现了很多12306的代码&#xff0c;但是都不是最新的&#xff0c;我也是从网上找别人的帖子&#xff0c;看B站视频&…

edeg插件/扩展推荐:助力生活工作

WeTab 此插件在我看来有2个作用 1.改变edeg的主页布局和样式,使其更加精简,无广告 2.提供付费webtab Ai(底层是chatGpt) 沉浸式翻译 此插件可翻译网页的内容 假设我们浏览github 翻译前 翻译后 Better Ruler 可以对网页的距离进行测量 适合写前端的小伙伴 用法示例:

正则表达式 - 使用总结

正则表达式 - 使用总结 正则表达式(Regular Expression,简称Regex)是一种强大的文本处理工具,它允许我们通过特定的模式(pattern)来搜索、匹配和操作字符串。在编程、数据分析和文本处理等领域,正则表达式发挥着非常重要的作用。本文将总结正则表达式的基本概念、使用方…

doris:基于 Arrow Flight SQL 的高速数据传输链路

Doris 基于 Arrow Flight SQL 协议实现了高速数据链路&#xff0c;支持多种语言使用 SQL 从 Doris 高速读取大批量数据。 用途​ 从 Doris 加载大批量数据到其他组件&#xff0c;如 Python/Java/Spark/Flink&#xff0c;可以使用基于 Arrow Flight SQL 的 ADBC/JDBC 替代过去…

数据挖掘——关联规则挖掘

数据挖掘——关联数据挖掘 关联数据挖掘关联规则关联规则挖掘问题&#xff1a;具体挖掘过程Apriori 产生关联规则 关联数据挖掘 关联分析用于发现隐藏在大型数据集中的令人感兴趣的联系&#xff0c;所发现的模式通常用关联规则或频繁项集的形式表示。 关联规则反映一个事物与…

DVWA靶场Brute Force (暴力破解) 漏洞low(低),medium(中等),high(高),impossible(不可能的)所有级别通关教程

目录 暴力破解low方法1方法2 mediumhighimpossible 暴力破解 暴力破解是一种尝试通过穷尽所有可能的选项来获取密码、密钥或其他安全凭证的攻击方法。它是一种简单但通常无效率的破解技术&#xff0c;适用于密码强度较弱的环境或当攻击者没有其他信息可供利用时。暴力破解的基…

[react] 纯组件优化子

有组件如下,上面变化秒数, 下面是大量计算的子组件,上面每一秒钟变化一次,这时候子组件会不断重新渲染, 浪费资源 父组件如下 import React, { memo, useEffect, useMemo, useState } from react; import type { ReactNode, FC } from react; import HugeCount from ./Te; int…

CSS进阶和SASS

目录 一、CSS进阶 1.1、CSS变量 1.2、CSS属性值的计算过程 1.3、做杯咖啡 1.4、下划线动画 1.5、CSS中的混合模式(Blending) 二、SASS 2.1、Sass的颜色函数 2.2、Sass的扩展(extend)和占位符(%)、混合(Mixin) 2.3、Sass的数学函数 2.4、Sass的模块化开发 2.5、Sass…

使用 Spring Boot 和 GraalVM 的原生镜像

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;历代文学&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编程&#xff0c;高并发设计&#xf…

清华大学Python包镜像站点

清华大学提供了一个Python包镜像站点&#xff0c;其中包括了许多常用的Python包。使用这个镜像站点可以提高下载Python包时的速度&#xff0c;因为包已经存储在国内的服务器上&#xff0c;从而减少了网络延迟。 要使用清华的pip镜像&#xff0c;你可以在pip命令中指定-i参数来…

【每日学点鸿蒙知识】tensorflowlite编译、音频编码线程、沉浸式状态栏、TextArea最大字节数限制等

1、如何编译Tensorflow lite库&#xff1f; 之前项目基于tflite推理引擎做人脸识别的功能&#xff0c;鸿蒙侧如何复用tflite模型&#xff1f; tflite对Android和iOS本身支配了GPU支持&#xff0c;但是鸿蒙侧目前并没有&#xff0c;鸿蒙提供了自己的推理引擎&#xff0c;而且支…

MySQL 索引优化实战 – 结合 Explain 深度解析慢查询

在实际的开发过程中&#xff0c;随着数据量的不断增大&#xff0c;慢查询成为了不可忽视的性能瓶颈。MySQL 提供了多种工具来帮助我们分析查询性能问题&#xff0c;其中最常用的工具是 EXPLAIN、SHOW PROFILE 和 SHOW STATUS。本文将从慢查询日志入手&#xff0c;结合 EXPLAIN …

【人工智能机器学习基础篇】——深入详解强化学习之常用算法Q-Learning与策略梯度,掌握智能体与环境的交互机制

深入详解强化学习之常用算法&#xff1a;Q-Learning与策略梯度 强化学习&#xff08;Reinforcement Learning, RL&#xff09;作为机器学习的一个重要分支&#xff0c;近年来在多个领域取得了显著成果。从棋类游戏的人机对战到自主驾驶汽车&#xff0c;强化学习技术展示了其强大…

计算机网络-L2TP VPN基础实验配置

一、概述 上次大概了解了L2TP的基本原理和使用场景&#xff0c;今天来模拟一个小实验&#xff0c;使用Ensp的网卡桥接到本地电脑试下L2TP拨号&#xff0c;今天主要使用标准的L2TP&#xff0c;其实在这个基础上可以加上IPSec进行加密&#xff0c;提高安全性。 拓扑说明&#xf…

Linux | 零基础Ubuntu解压RaR等压缩包文件

目录 介绍 案例分析 安装工具 解压实践 介绍 RAR是一种专利文件格式&#xff0c;用于数据压缩与归档打包&#xff0c;开发者为尤金罗谢尔&#xff08;俄语&#xff1a;Евгений Лазаревич Рошал&#xff0c;拉丁转写&#xff1a;Yevgeny Lazarevich R…