MYSQL内存请求一直不释放_记一次mysql内存占用过大-不释放问题排查

问题描述:mysql

接线上报警,mysql所在服务器内存剩余不足,这个实例内存问题是周期性爆发的,经过监控看到内存平均2天就被用尽掉256GB。sql

排查思路:服务器

一、单个实例占用内存256GB,首先想到的是bufferpool,确认配置session

show global variables like '%innodb_buffer_pool_size%';orm

30GB,内存

SELECT @@innodb_buffer_pool_instances;get

innodb_buffer_pool_instances配置的是1io

二、查看当前实例内存表占用innodb

SELECT SUM(max_data_length)/1024/1024 AS MEMORY_MB FROM information_schema.tables WHERE ENGINE='memory';

64MBtable

三、当前实例非系统帐号链接为5,因此计算session共占用最大内存为:

SELECT ( ( @@read_buffer_size

+ @@read_rnd_buffer_size

+ @@sort_buffer_size

+ @@join_buffer_size

+ @@binlog_cache_size

+ @@thread_stack

+ @@max_allowed_packet

+ @@net_buffer_length )

) / (1024*1024)*8 AS MEMORY_MB;

315MB

问题老是让咱们秃头,经过free -g查看,cache占用很是的大,想起来numa这个东东,接下来抱着试一试的态度执行了如下操做:

1)mysql开启numa interleave访问(mysql_safe中增长一行代码,不知的同窗自行搜一下哈)

2)重启实例,问题解决

总结:以前遇到的内存问题,通常都是由于bp配置太高,或者链接数猛增配置不合理致使的。这里顺便推荐一款mysql内存计算器,http://www.mysqlcalculator.com/ 用于查看你的内存配置是否合理

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值