一、 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
&n