如何计算MySQL数据库占用内存

简介

估计有很多开发,或者刚刚接触MySQL数据库的运维人员,不太清楚,如何去计算MySQL数据库占用内存总大小。
估计有时候,还会奇怪,明明设置的buffer pool size不大,数据库却因为操作系统内存不足,导致MySQL数据库进程被系统自动kill掉了。
下面就来给你一一揭晓答案

MySQL数据占用内存

MySQL数据库占用操作系统内存,主要分为两部分

  • 第一部分为:innodb存储引擎占用的buffer pool size,一部分为myism存储引擎占用的内存大小
  • 第二部分为:MySQL数据库应用会话占用的内存大小

MySQL数据库内存计算公式

1.buffer pool内存占用计算方式
buffer pool目前主要有innodb和myism2个存储引擎,还有一个是redo日志占用内存大小,innodb_log_buffer_size

mysql> SELECT ( @@innodb_buffer_pool_size
    ->          + @@innodb_log_buffer_size
    ->          + @@key_buffer_size ) / 1024 / 1024 AS MEMORY_MB;
+--------------+
| MEMORY_MB    |
+--------------+
| 584.00000000 |
+--------------+
1 row in set (0.00 sec)

2.MySQL数据库会话占用内存大小
可以使用下面的公式计算一个会话占用内存的大小

mysql> SELECT ( @@read_buffer_size + @@read_rnd_buffer_size
    ->          + @@sort_buffer_size + @@tmp_table_size
    ->          + @@join_buffer_size + @@binlog_cache_size ) / 1024 / 1024 AS Session_MB;
+-------------+
| Session_MB  |
+-------------+
| 16.90625000 |
+-------------+
1 row in set (0.00 sec)

在这里需要注意,有时候,因为你的数据库整体性能下降之后,应用可能会有突然激增很多数据库连接,可能会造成操作系统的内存不足,而导致被系统自动kill掉进程。所以在设计数据库的时候,一定要考虑数据库承载的最大连接数。

计算所有连接数占用的总内存大小。

先查询出数据库有多少会话
mysql> select count(*) from INFORMATION_SCHEMA.PROCESSLIST;
+----------+
| count(*) |
+----------+
|        1 |
+----------+
1 row in set (0.00 sec)

根据会话数去乘一个会话占用内存的大小,最后得到的就是会话占用的内存总大小。

参考链接 :

如何计算MySQL数据库占用内存 :
https://mp.weixin.qq.com/s/_aOCYw0IxJDEjXWOZRPV4w

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值