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

mysql内存数据库(如何计算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内存数据库(如何计算MySQL数据库占用内存)

mysql> SELECT ( @@innodb_buffer_pool_size -> + @@innodb_log_buffer_size -> + @@key_buffer_size ) / 1024 / 1024 AS MEMORY_MB;+--------------+| MEMORY_MB |+--------------+| 584. |+--------------+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. |+-------------+1 row in set (0.00 sec)

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

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

关于mysql内存数据库的内容到此结束,希望对大家有所帮助。

文章版权声明:除非注明,否则均为边学边练网络文章,版权归原作者所有