数据库

 首页 > 数据库 > MySql > MYSQL,innodb_buffer_pool_size内存分配方式

MYSQL,innodb_buffer_pool_size内存分配方式

分享到:
【字体:
导读:
         摘要:以前一直以为MYSQL,innodb_buffer_pool_size=8G,MySQL一起动就会将占用掉8G内存(认为TOP可以看到内存被使用了8G),但是最近才仔细研究一下,原来不是这样的(可能自己对Linux malloc内存分配也只是知道了个皮毛吧),MySQL启动时实际只是在虚拟内存中分配了地址空间,而并没有...

MYSQL,innodb_buffer_pool_size内存分配方式

以前一直以为MYSQL,innodb_buffer_pool_size=8G,MySQL一起动就会将占用掉8G内存(认为TOP可以看到内存被使用了8G),但是最近才仔细研究一下,原来不是这样的(可能自己对Linux malloc内存分配也只是知道了个皮毛吧),MySQL启动时实际只是在虚拟内存中分配了地址空间,而并没有真正的映射到物理内存上。

因为malloc分配内存是先在虚拟内存中分配地址的,到实际使用时才真正的映射到物理内存

因此这个地方,如果由于机器内存使用不当,到了MySQL真正要映射物理内存时,如果物理内存不足了,就会出错甚至退出。


但是这里也有个很奇妙的地方就是Linux下的OOM Killer:

假如我一个程序A已经运行,并且分配了22G内存(机器配置是物理内存16G+SWAP 8G),但是没有真正的映射到物理内存;

这时MySQL启动,innodb_buffer_pool_size=8G,启动正常;

然后程序A开始实际分配物理内存,一下子只剩下2G SWAP内存了;

这时MYSQL也开始实际使用内存,因为只有2G SWAP,所以性能很差,再超过2G时,内存耗尽,这时OOM Killer开始杀进程,怎么杀呢,谁占用内存多杀谁,于是将进程A杀掉了,内存一下子回来了,MySQL不会退出;

但是一般系统中MySQL都是分配内存最大的,所以经常性的是MySQL被杀掉。


Linux OOM Killer可参见:理解和配置 Linux 下的 OOM Killer

MYSQL,innodb_buffer_pool_size内存分配方式
分享到:
AWR报告的生成和简单分析方法
AWR报告的生成和简单分析方法生成AWR报告方法: 第一步:数据库压力测试卡开始时:生成第一个快照: Sql>exec dbms_workload_repository.create_snapshot(); 第二步:数据库压力测试结束时:生成第二个快照 Sql>exec dbms_workload_repository.create_snapshot(); 第三步:生成AWR报告 SQL> @/oracle/product/10.2.0.5/rdbm...
SQL中数据库之间不兼容的语法汇总
SQL中数据库之间不兼容的语法汇总1.TOP SQL Server的语法: SELECT TOP number columnName FROM tableName MySQL的语法: SELECT columnName FROM tableName LIMIT number Oracle的语法: SELECT columnName FROM tableName WHERE ROWNUM
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……