IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

Innodb分表太多或者表分区太多,会导致内存耗尽而宕机

MySQL实验室 2009-10-19 23:23:18 累计浏览 7,719 次
本机暂存

    因为线上某个应用表分区太多,直接导致遍历表或者dump数据的时候导致内存耗尽死机。原因是Innodb的数据字典不会释放内存,会将所有表和分区的信息记录在内存当中,当表数量或者分区数到达一定数量之后(经验值:约10万张表或者10万个表分区,占用将近1G大小的内存),会导致内存耗尽。

    my.cnf 配置参数: innodb_additional_mem_pool_size

    查看数据字典使用多少内存:

SHOW engine innodb STATUS\\G

    Dictionary memory allocated xxxxxxx

    针对这种情况,Vadim提供了一个限制数据字典占用内存大小(Limiting InnoDB Data Dictionary)的补丁,用来限制数据字典占用内存的大小,采用LRU淘汰算法,只保留最新使用的表信息。

同分类推荐文章

  1. 使用deepseek进行Oracle恢复,引起重大故障 (2026-06-22 10:56:00)
  2. 接手一个只差临门一脚的数据库恢复 (2026-06-18 00:13:09)
  3. 我做了一个 AI 版的 StarRocks 升级风险扫描工具,直接帮我定位到一个风险 (2026-06-15 01:00:00)

查看更多 数据库 文章 →

建议继续学习

  1. 用Hyer来进行网站的抓取 (累计阅读 158,251)
  2. MySQL数据库在实际应用一些方面的介绍 (累计阅读 36,397)
  3. WordPress插件开发 -- 在插件使用数据库存储数据 (累计阅读 29,164)
  4. Java开发岗位面试题归类汇总 (累计阅读 22,156)
  5. Mysql监控指南 (累计阅读 21,351)
  6. 由浅入深探究mysql索引结构原理、性能分析与优化 (累计阅读 16,523)
  7. Linux内存点滴 用户进程内存空间 (累计阅读 13,229)
  8. 在Apache2.2.XX下安装Mod-myvhost模块 (累计阅读 13,057)
  9. 15个最好的免费开源电子商务平台 (累计阅读 12,541)
  10. 浅谈MySQL索引背后的数据结构及算法 (累计阅读 11,904)