如何有效利用MYSQL的连接数

连接数配置2500~3000 依然发现连接不够用?

-- 查看当前最大连接数
SHOW VARIABLES LIKE 'MAX_CONNECTIONS';
-- 查看当前总链接数
SHOW STATUS LIKE 'Threads_connected';
-- 查看当前进程明细
SHOW PROCESSLIST;

合理设置以下参数:

1. MySQL 的参数设置

MySQL 有两个关键参数控制连接的空闲超时时间:

wait_timeout
  • 作用:控制非交互式连接(如通过 JDBC、ODBC 等程序连接的客户端)的空闲超时时间。

  • 默认值:28800 秒(8 小时)。

  • 建议值:根据业务需求设置,通常可以设置为 600 秒(10 分钟)。

interactive_timeout
  • 作用:控制交互式连接(如通过 MySQL 命令行客户端或 PHPMyAdmin 等工具连接的客户端)的空闲超时时间。

  • 默认值:28800 秒(8 小时)。

  • 建议值:与 wait_timeout 保持一致,通常设置为 600 秒(10 分钟)。

设置方法
  • 临时设置(重启后失效):

    sql

    复制

    SET GLOBAL wait_timeout = 600;
    SET GLOBAL interactive_timeout = 600;
  • 永久设置(修改配置文件):
    在 MySQL 配置文件(my.cnf 或 my.ini)中添加或修改以下内容:

    ini

    复制

    [mysqld]
    wait_timeout = 600
    interactive_timeout = 600

    然后重启 MySQL 服务。


2. HikariCP 连接池的参数设置

HikariCP 是一个高性能的连接池,以下是关键参数及其与 MySQL 超时设置的关联:

max-lifetime
  • 作用:控制连接在连接池中的最大存活时间。超过该时间的连接会被销毁并重新创建。

  • 建议值:设置为小于 MySQL 的 wait_timeout 和 interactive_timeout 的值。例如,如果 MySQL 的超时时间是 600 秒,可以将 max-lifetime 设置为 540000 毫秒(9 分钟)。

  • 单位:毫秒。

idle-timeout
  • 作用:控制连接在连接池中的最大空闲时间。超过该时间的空闲连接会被销毁。

  • 建议值:根据业务需求设置,通常可以设置为 60000 毫秒(1 分钟)。

  • 单位:毫秒。

connection-timeout
  • 作用:控制从连接池获取连接的最大等待时间。如果超时,会抛出异常。

  • 建议值:通常设置为 30000 毫秒(30 秒)。

  • 单位:毫秒。

minimum-idle
  • 作用:控制连接池中保持的最小空闲连接数。

  • 建议值:根据业务需求设置,通常可以设置为 10~50。

  • 注意:设置过高会导致资源浪费,设置过低可能影响性能。

maximum-pool-size
  • 作用:控制连接池的最大连接数。

  • 建议值:根据业务需求和数据库性能设置,通常可以设置为 100~200。


3. 配置示例

以下是一个完整的 HikariCP 配置示例(以 Spring Boot 的 application.yml 为例):

yaml

复制

spring:
  datasource:
    hikari:
      connection-test-query: SELECT 1  # 连接测试查询
      connection-timeout: 30000       # 连接获取超时时间(30 秒)
      maximum-pool-size: 150          # 最大连接数
      max-lifetime: 540000           # 连接最大存活时间(9 分钟)
      minimum-idle: 10               # 最小空闲连接数
      idle-timeout: 60000            # 空闲连接超时时间(1 分钟)

4. 参数之间的关系

  • MySQL 的 wait_timeout 和 interactive_timeout:控制 MySQL 服务器关闭空闲连接的时间。

  • HikariCP 的 max-lifetime:控制连接在连接池中的最大存活时间。

  • HikariCP 的 idle-timeout:控制连接在连接池中的最大空闲时间。

关键点

  • max-lifetime 必须小于 MySQL 的 wait_timeout 和 interactive_timeout,否则连接池中的连接可能会被 MySQL 关闭,导致应用使用无效连接。

  • idle-timeout 可以适当设置,以定期清理空闲连接,避免资源浪费。


5. 验证配置

  • 使用 SHOW VARIABLES LIKE 'wait_timeout'; 和 SHOW VARIABLES LIKE 'interactive_timeout'; 确认 MySQL 的超时设置。

  • 使用 SHOW PROCESSLIST; 查看 MySQL 的连接状态,确认是否有大量 Sleep 状态的连接。

  • 监控 HikariCP 的连接池状态,确保连接池中的连接数在合理范围内。


6. 总结

  • MySQL 设置

    ini

    复制

    wait_timeout = 600
    interactive_timeout = 600
  • HikariCP 设置

    yaml

    复制

    hikari:
      max-lifetime: 540000
      idle-timeout: 60000
      connection-timeout: 30000
      minimum-idle: 10
      maximum-pool-size: 150

通过以上配置,可以确保 MySQL 和 HikariCP 的参数设置是合理的,避免连接被关闭或连接池使用无效连接的问题。

wait_timeout 和 interactive_timeout 通常需要同时设置,因为它们分别控制不同类型的连接空闲超时时间。以下是具体原因和建议:


1. wait_timeout 和 interactive_timeout 的区别

  • wait_timeout:

    • 适用于非交互式连接(如通过 JDBC、ODBC 等程序连接的客户端)。

    • 控制连接在空闲状态下的最大存活时间。

  • interactive_timeout:

    • 适用于交互式连接(如通过 MySQL 命令行客户端或 PHPMyAdmin 等工具连接的客户端)。

    • 控制连接在空闲状态下的最大存活时间。


2. 为什么要同时设置?

  • 如果只设置 wait_timeout,交互式连接的空闲超时时间仍然会使用默认的 interactive_timeout 值。

  • 如果只设置 interactive_timeout,非交互式连接的空闲超时时间仍然会使用默认的 wait_timeout 值。

  • 为了确保所有类型的连接都遵循相同的空闲超时规则,建议同时设置这两个参数。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构-图-找出星型图的中心节点

力扣题目:1791. 找出星型图的中心节点 - 力扣(LeetCode) 有一个无向的 星型 图,由 n 个编号从 1 到 n 的节点组成。星型图有一个 中心 节点,并且恰有 n - 1 条边将中心节点与其他每个节点连接起来。 给你一个二维整数…

计算机网络之物理层——基于《计算机网络》谢希仁第八版

(꒪ꇴ꒪ ),Hello我是祐言QAQ我的博客主页:C/C语言,数据结构,Linux基础,ARM开发板,网络编程等领域UP🌍快上🚘,一起学习,让我们成为一个强大的攻城狮&#xff0…

VScode C语言学习开发环境;运行提示“#Include错误,无法打开源文件stdio.h”

C/C环境配置 参考: VS Code 配置 C/C 编程运行环境(保姆级教程)_vscode配置c环境-CSDN博客 基本步骤 - 安装MinGW-W64,其包含 GCC 编译器:bin目录添加到环境变量;CMD 中输入gcc --version或where gcc验证…

计算机毕业设计Python农产品推荐系统 农产品爬虫 农产品可视化 农产品大数据(源码+LW文档+PPT+讲解)

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…

(学习总结25)Linux工具:vim 编辑器 和 gcc/g++ 编译器

Linux工具:vim 编辑器 和 gcc/g 编译器 vim 编辑器在 Linux 命令行中执行 vimvim 命令模式光标操作相关命令文本或字符操作命令撤销操作命令查找操作 vim 插入模式vim 底行模式查找与编写操作界面操作文件处理操作vim 与 shell 交互其它操作退出 vim 一般操作 vim 可…

IntelliJ IDEA中Maven配置全指南

一、环境准备与基础配置 1.1 Windows 环境下载并配置 Maven 见此篇博文:环境配置 1.2 IDEA配置步骤 打开设置面板:File → Settings → Build → Build Tools → Maven 关键配置项: Maven home path E:\apache-maven-3.9.9 (…

第4章 信息系统架构(三)

4.3 应用架构 应用架构的主要内容是规划出目标应用分层分域架构,根据业务架构规划目标应用域、应用组和目标应用组件,形成目标应用架构逻辑视图和系统视图。从功能视角出发,阐述应用组件各自及应用架构整体上,如何实现组织的高阶…

Ubuntu 20.04源码安装opencv 4.5.0

安装依赖项 sudo apt install -y g sudo apt install -y cmake sudo apt install -y make sudo apt install -y wget unzip安装opencv依赖库 sudo apt-get install build-essential libgtk2.0-dev libgtk-3-dev libavcodec-dev libavformat-dev libjpeg-dev libswscale-dev l…

前端如何转战鸿蒙

前端如何转战鸿蒙系统 在当今技术日新月异的时代,前端开发者们不断探索新的领域和机会。随着鸿蒙系统的崛起,一个全新的生态正等待着前端开发者们去开拓。那么,作为前端开发者,我们为何要转战鸿蒙系统?又该如何顺利转型…

Linux(ubuntu) GPU CUDA 构建Docker镜像

一、创建Dockerfile FROM ubuntu:20.04#非交互式,以快速运行自动化任务或脚本,无需图形界面 ENV DEBIAN_FRONTENDnoninteractive# 安装基础工具 RUN apt-get update && apt-get install -y \curl \wget \git \build-essential \software-proper…

新能源汽车核心元件揭秘:二极管、三极管结构与工作原理解析(2/2)

上一节我们讲了二极管的原理, 原文章: https://zhuanlan.zhihu.com/p/25252117833 看了的朋友应该很容易懂这节课 这篇文章我们来说说三极管的工作原理啊 这里要说下几个概念 1 半导体的导通, 就是说里面的负电荷电子和正电荷空穴可以大量的从 一个地方达到我们想要的地方…

2024年数学SCI1区TOP:改进海洋捕食者算法MMPA用于UAV路径规划,深度解析+性能实测

目录 1.摘要2.海洋捕食者算法MPA原理3.改进策略4.结果展示5.参考文献6.获取代码 1.摘要 本文提出了一种改进海洋捕食者算法(MMPA),用于解决具有多重威胁的复杂环境中的全局优化问题,针对无人机(UAV)路径规…

QML ToolButton与DelayButton的使用、详解与自定义样式

QML MenuBarItem与MenuItem的使用、详解与自定义样式 一、介绍1、ToolButton常见用法基础示例设置图标 常用属性texticonenabledshortcutcheckable & checked 信号onClickedonPressed 和 onReleased 样式和外观使用场景 2、DelayButton使用场景核心属性1. delay 核心信号1.…

Linux下基本指令(4)

Linux权限的概念 Linux下有两种用户:超级用户(root)、普通用户。 超级用户:可以再linux系统下做任何事情,不受限制 普通用户:在linux下做有限的事情。 超级用户的命令提示符是“#”,普通用户…

网络安全设备防护原理 网络安全防护装置

🍅 点击文末小卡片 ,免费获取网络安全全套资料,资料在手,涨薪更快 防火墙 简介 网络层的防护设备,依照特殊的规则允许或者限制传输的数据通过 是由软件和硬件设备组合而成,在内部网和外部网之间、专用网…

windwos与linux环境下Iperf3带宽测试工具的安装、使用

目录 一、前言 二、windows 2.1下载 2.2安装 2.3使用 2.3.1服务端 2.3.2客户端 2.3.3输出内容 1.客户端 2.服务端 2.4.相关命令 三、linux 3.1安装 3.2使用 1.服务端 2.客户端 3.输出内容 1.客户端 2.服务端 一、前言 在数字化浪潮下,网络性能…

达梦统计信息

统计信息 统计信息概述 统计信息是数据库中关于表和索引数据的元信息,用于描述数据的分布、唯一性、大小等特征。数据库优化器依赖统计信息来选择最优的执行计划。统计信息对于 CBO(基于代价的优化器)生成执行计划具有直接影响。 收集统计…

【面试系列】Java开发--AI常见面试题

1、实际工作或学习中用过哪些Ai工具 1.1、AI编程1.2、AI对话聊天1.3、AI图像工具1.4、AI办公工具 2、谈谈你知道的AI领域的一些常见词汇及其含义的理解? 例如AIGC、LLM、DeepLearning分别是什么意思? 2.1、AIGC(Artificial Intelligence Gene…

一文讲解Redis为什么读写性能高以及I/O复用相关知识点

Redis为什么读写性能高呢? Redis 的速度⾮常快,单机的 Redis 就可以⽀撑每秒十几万的并发,性能是 MySQL 的⼏⼗倍。原因主要有⼏点: ①、基于内存的数据存储,Redis 将数据存储在内存当中,使得数据的读写操…

OnlyOffice:前端编辑器与后端API实现高效办公

OnlyOffice:前端编辑器与后端API实现高效办公 一、OnlyOffice概述二、前端编辑器:高效、灵活且易用1. 完善的编辑功能2. 实时协作支持3. 自动保存与版本管理4. 高度自定义的界面 三、后端API:管理文档、用户与权限1. 轻松集成与定制2. 实时协…