MySQL 内存使用率常用分析语句(收藏版)

 更新时间:2025年07月30日 14:58:04   作者:Hehuyi_In  
用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据汇总和按用户排序的内存分布分析,对MySQL 内存使用率相关知识感兴趣的朋友一起看看吧

最近连续遇到MySQL内存占用过高导致服务器内存不足的问题,整理下收集到的常用分析语句。

关于MySQL内存使用率高问题排查过程以及解决方案,可以参考这篇文章。

一、 OS层

首先需要确认是否是MySQL占用的内存

top -p $(pidof mysqld) -n 1

或者

cat /proc/$(pidof mysqld)/status

二、 DB层

1. 全局情况

  • 各种buffer pool大小,是否有明显不合理的设置
SHOW GLOBAL VARIABLES LIKE '%buffer%szie%';

  • MySQL总占用内存
SELECT * FROM sys.memory_global_total;

2. 内存占用详情

  • 按内存模块
SELECT
  EVENT_NAME,
  CURRENT_NUMBER_OF_BYTES_USED AS memory_bytes,
  CURRENT_NUMBER_OF_BYTES_USED / 1024 / 1024 AS memory_mb
FROM
  performance_schema.memory_summary_global_by_event_name
WHERE
  CURRENT_NUMBER_OF_BYTES_USED > 0
ORDER BY
  CURRENT_NUMBER_OF_BYTES_USED DESC
LIMIT 10;

  • 各模块内存使用变化(结果是累计值,可以根据差值观察变化情况)

多次查询,求差值

SELECT
  EVENT_NAME,
  SUM(SUM_NUMBER_OF_BYTES_ALLOC) / 1024 / 1024 AS total_memory_mb
FROM
  performance_schema.memory_summary_global_by_event_name
GROUP BY
  EVENT_NAME
ORDER BY
  SUM_NUMBER_OF_BYTES_ALLOC DESC
LIMIT 10;

  • 按线程查看内存占用
SELECT
  m.EVENT_NAME,
  m.COUNT_ALLOC,
  m.CURRENT_NUMBER_OF_BYTES_USED AS mem_sum,
  (m.CURRENT_NUMBER_OF_BYTES_USED / 1024 / 1024.0) AS mem_sum_mb,
  t.NAME,
  t.TYPE,
  t.PROCESSLIST_ID,
  LEFT(t.PROCESSLIST_INFO, 10)
FROM
  performance_schema.memory_summary_by_thread_by_event_name m
  JOIN performance_schema.threads t
 USING (THREAD_ID)
WHERE   
 t.PROCESSLIST_ID != CONNECTION_ID()
ORDER BY
  m.CURRENT_NUMBER_OF_BYTES_USED desc
LIMIT 10;

sys库中的视图基于 performance_schema 提供了更易读和易用的性能数据汇总

SELECT * FROM sys.memory_by_thread_by_current_bytes LIMIT 10;

  • 内存分布详情
SELECT * FROM sys.memory_global_by_current_bytes order by current_alloc desc LIMIT 10;

  • 按用户排序
SELECT * FROM sys.memory_by_user_by_current_bytes;

到此这篇关于MySQL 内存使用率常用分析语句的文章就介绍到这了,更多相关MySQL 内存使用率内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 用Autoconf检测MySQL软件包的教程

    用Autoconf检测MySQL软件包的教程

    这篇文章主要介绍了用Autoconf检测MySQL软件包的教程,主要使用编写好的ax_lib_mysql脚本进行操作,需要的朋友可以参考下
    2015-06-06
  • mysql中Load Data记录换行问题的解决方法

    mysql中Load Data记录换行问题的解决方法

    有关mysql中Load Data记录换行的问题的解决方法, 需要的朋友可以参考下
    2013-02-02
  • MySQL  zip安装包配置教程

    MySQL  zip安装包配置教程

    这篇文章详细介绍了如何使用zip安装包在Windows11上安装MySQL8.0,包括下载、解压、配置环境变量、初始化数据库、安装服务以及更改密码等步骤,感兴趣的朋友一起看看吧
    2025-02-02
  • Mysql字符集和排序规则详解

    Mysql字符集和排序规则详解

    这篇文章主要介绍了Mysql字符集和排序规则详解,在mysql中存储的是字符串数据,那么这些数据到底在Mysql中如何存储呢?这就涉及到字符集的概念,接下来我们一起进入文章学习详细内容介绍吧
    2022-09-09
  • MySQL如何追踪数据库中对特定表的更新操作

    MySQL如何追踪数据库中对特定表的更新操作

    这篇文章主要为大家详细介绍了五种不同的方法 来追踪 MySQL 数据库中对特定表(如 statistics_test)的更新操作,并提供详细的代码示例和适用场景分析,希望对大家有所帮助
    2025-06-06
  • mysql增量备份及恢复的操作方法

    mysql增量备份及恢复的操作方法

    增量备份是在全备或上次增量备份基础上,只备份新增或修改的文件,减少数据量和时间,binlog记录数据库变更,重启时创建新日志文件,增量备份复杂但减轻服务器负担,而binlog帮助精确恢复数据
    2023-09-09
  • 深入理解MySQL默认事物隔离级别

    深入理解MySQL默认事物隔离级别

    本文主要介绍了深入理解MySQL默认事物隔离级别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2026-03-03
  • mysql error:#1062 Duplicate entry ‘***′ for key 1问题解决方法

    mysql error:#1062 Duplicate entry ‘***′ for key 1问题解决方法

    今天公司的一个网站突然提示MySQL Error Duplicate entry '96624' for key 1错误,经过分析这个问题是由于mysql表中的一个id自增长字段导致。
    2011-09-09
  • 在MAC OS X上安装MYSQL

    在MAC OS X上安装MYSQL

    MAC系统自带apache和php,但是没有mysql,那么我们只好自力更生了,经过一番研究,借鉴网上一位大神的文章,终于成功安装上了mysql,这里推荐给有需要的朋友
    2014-10-10
  • MySQL复合查询和表的内外连接示例详解

    MySQL复合查询和表的内外连接示例详解

    在数据库管理和数据分析中,单表查询往往无法满足复杂的数据查询需求,因此多表查询和子查询成为了解决问题的关键技术,MySQL支持多种多表查询方式,如内连接、外连接(左外连接和右外连接)以及自连接,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-10-10

最新评论