如何优化mysql内存占用高导致宕机

1,首先通过任务管理器进行进程排序,查找占用内存较大的程序进程。一般占用内存较大的进程有W3WP、sqlserver、mysqld-nt.exe;2, 站点进程w3wp 可以在cmd命令行中通过 iisapp 命令来对应是那个网站占用内存较大。可以通过设置回收时间、内存最大使用值或共用进程池来减少内存的占用,但是如果要保证网站的...
如何优化mysql内存占用高导致宕机
1,首先通过任务管理器进行进程排序,查找占用内存较大的程序进程。一般占用内存较大的进程有W3WP、sqlserver、mysqld-nt.exe;
2, 站点进程w3wp 可以在cmd命令行中通过 iisapp 命令来对应是那个网站占用内存较大。可以通过设置回收时间、内存最大使用值或共用进程池来减少内存的占用,但是如果要保证网站的访问质量,还是建议升级至更高型号来解决;
3,数据库 sql server 也可以通过数据库的企业管理器来设置最大内存占用,但是如果网站程序必须要占用较大内存的话,设置后会发生页面报错、打不开等问题;
4,MYSQL本身会占用较大虚拟内存,如果不使用mysql数据库的话,可以将其停止。2017-11-24
查看 /proc/meminfo
Tips:
“大内存页”也称传统大页、大页内存等有助于 Linux 进行虚拟内存的管理,标准的内存页为 4KB,这里使用“大内存页”最大可以定义 1GB 的页面大小,在系统启动期间可以使用“大内存页”为应用程序预留一部分内存,这部分内存被占用且永远不会被交换出内存,它会一直保留在那里,直到改变配置。(详细介绍请看下面链接官方解释)
那么这么大页内存是分配给谁的呢?
查询一下:
shell> /proc/sys/vm/hugetlb_shm_group

27
shell> id 27
uid=27(mysql) gid=27(mysql) groups=27(mysql)
hugetlb_shm_group 文件里填的是指定大页内存使用的用户组 id,这里查看到是 MySQL 组 id,那既然是给 MySQL 的为什么 free 等于 total,并且 mysql 还只有 20 多 G 实际使用内存呢?
原来在 MySQL 中还有专门启用大内存页的参数,在 MySQL 大内存页称为 large page。
查看 MySQL 配置文件
发现配置文件中确实有 large-page 配置,但出于禁用状态。

后与业务确认,很早之前确实启用过 mysql 的 large page,不过后面禁用了。排查到这基本就有了结论。
结论

这套环境之前开启了 20000 的大内存页,每页大小为 2MB,占用了 40G 内存空间,给 MySQL 使用,并且 MySQL 开启了 large page,但后来不使用的时候,只关闭了 MySQL 端的 large page 参数,但没有实际更改主机的关于大内存页的配置,所以导致,实际上主机上的还存在 20000 的大内存页,并且没在使用,这一部分长期空闲,并且其他程序不能使用。
所以 MySQL 在使用 20G 内存左右,整个主机内存就饱和了,然后在部分条件下,就触发了 OOM,导致 mysqld 被 kill,但主机上又有 mysqld_safe 守护程序,所以又再次给拉起来,就看到了文章初的偶尔连接不上的现象。2020-12-30
mengvlog 阅读 6 次 更新于 2025-07-20 00:50:39 我来答关注问题0
  • 1,首先通过任务管理器进行进程排序,查找占用内存较大的程序进程。一般占用内存较大的进程有W3WP、sqlserver、mysqld-nt.exe;2, 站点进程w3wp 可以在cmd命令行中通过 iisapp 命令来对应是那个网站占用内存较大。可以通过设置回收时间、内存最大使用值或共用进程池来减少内存的占用,但是如果要保证网站的...

  •  翡希信息咨询 如何解决mysql启动时性能_schema占用内存过高的问题?

    关闭Performance Schema:方法:在MySQL配置文件的[mysqld]部分添加performance_schema = off。效果:关闭Performance Schema后,MySQL的内存占用会有显著降低,通常可以降至40MB左右。这对于那些不需要实时性能监控的服务器环境尤其有效。调整相关配置参数:参数:可以尝试调整performance_schema_max_table_instances...

  • MySQL 5.6版本以后,Performance Schema默认开启,用于收集服务器性能数据,但这也可能导致内存占用增加。解决方法是关闭Performance Schema。在MySQL配置文件的[mysqld]部分添加"performance_schema = off",然后重启MySQL服务。这样做后,内存占用大约降至40MB,这是一个明显的改进。虽然之前在网上找到很多文...

  •  翡希信息咨询 mysql 5.6与5.7内存参数优化内存占用为30MB左右

    使用文本编辑器打开MySQL的配置文件/etc/my.cnf。调整关键参数:innodb_buffer_pool_size:设置为2M。这个参数决定了InnoDB存储引擎的缓冲池大小,是MySQL内存占用的主要部分之一。performance_schema_max_table_instances:设置为较小的值,如50,以减少性能模式占用的内存。table_definition_cache 和 table_o...

  • 要解决MySQL内存占用过大的问题,首先需要找到并修改配置文件。对于Windows Service 2016,配置文件通常位于C:\ProgramData\MySQL\MySQL Server 8.0\my.ini;对于CentOS7,则在/etc/my.cnf。如果配置文件已被修改,应根据实际情况找到正确路径。调整的关键配置项包括:table_definition_cache:设置为400。此...

檬味博客在线解答立即免费咨询

mySQL相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部