mysql内存占用_MySQL案例-内存使用率无限增长

本文描述了作者在遇到MySQL服务器内存使用率持续增长的问题时,进行了详细的分析过程。首先检查了buffer相关参数,接着通过pmap -d查看进程内存情况,发现匿名内存(anon)占用过高。进一步利用MySQL 5.7的Performance Schema检查线程内存使用,发现thread/sql/slave_sql和thread/sql/one_connection线程占用异常。经过排查,官方建议关闭并行复制以解决问题。
摘要由CSDN通过智能技术生成

拖了好久了, 抽空补上_(:з」∠)_

-------------------------------------------------------------------------------------------------正文---------------------------------------------------------------------------------------------------------------

背景: 收到内存报警的信息以后, 从监控中发现MySQL服务器的内存使用率在不断的增长;

附图:

978481263ca81d37d867a05f2c17e7b6.png

虽然进行了重启, 但是内存占用率依然会不停的增长,大约在半个月左右的时间内又把内存消耗完毕;

场景: 未搭建场景, 数据库版本 5.7.12

分析:

PS: 时间久远,截图仅做分析/示例所用, 不一定是当时候出问题时的数据

尝试方向1:

首先考虑的是buffer相关的参数是否设置有误, 毕竟当初crash的时候曾经出现过类似的问题(http://blog.itpub.net/29510932/viewspace-2123096/)

结果: 参数设置都没什么明显的问题;

尝试方向2:

既然设置没什么问题, 那就看一下内存的占用情况吧~

使用pmap -d看一下进程的内存情况; 部分信息截图如下

8a5b1d6f8e0dfce631ebf7ecd4ab31ff.png

anon代表进程主动申请的内存,当时对有问题的机器进行统计时, 发现主动申请的内存占了进程内存的95%(当然的..因为buffer都在这里面)

考虑到innodb_buffer_pool的大小只有总内存的50%,多出来的这些"已申请"的内存实在是有点太多了, 是不是有什么线程申请了大量的内存没有释放?

尝试方向2--检查线程的内存使用:

MySQL5.7中对ps(performance_schema)进行了拓展, 能统计更多的数据了, 这其中就包括了有关mem的信息;

由于默认是关闭的, 所以现在要临时打开这些统计数据;

点击(此处)折叠或打开

update performance_schema.setup_instruments set enabled = 'yes' where name like 'memory%'

执行上述语句之后, 在ps里面就能在mem相关的表里面看到相关的统计信息了; 如下图:

e73f63423b4ed9940e56c5574f32e72b.png

其中CURRENT_NUMBER_OF_BYTES_USED可以近似的当成目前占用的内存总数;

PS: 由于这个统计信息并不会区分共享内存,所以有可能会出现占用内存为负数, 或者各个项的总和大于实际占用内存总数;

由于是怀疑线程, 所以用CURRENT_NUMBER_OF_BYTES_USED倒序, 查询Thread相关的表; 结果类似下图:

dc385e0a38ca1fd8d9b363eb7b22bab5.png

当时有问题的实例中, 查询结果结合ps.thread表数据,显示thread/sql/slave_sql和thread/sql/one_connection(monitor用户)的内存占用非常高~

尝试方向2--分析线程:

thread/sql/slave_sql是同步中的SQL线程,负责复现主库binlog中的事务, 这个线程占用大量内存却不进行释放的现象, 第一反应不是我们自己的问题;

在mysql bug上面找了一圈,发现以前有人提交了类似的bug(https://bugs.mysql.com/bug.php?id=71197), 状态为close;

官方给出的解决方案是关闭并行复制, 并且把

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值