加入收藏 | 设为首页 | 会员中心 | 我要投稿 拼字网 - 核心网 (https://www.hexinwang.cn/)- 云上网络、混合云网络、数据仓库、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL占用内存过大怎么解决

发布时间:2023-12-31 12:22:47 所属栏目:MySql教程 来源:DaWei
导读: 这篇文章主要介绍“MySQL占用内存过大如何解决”,在日常操作中,相信很多人在MySQL占用内存过大如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对
这篇文章主要介绍“MySQL占用内存过大如何解决”,在日常操作中,相信很多人在MySQL占用内存过大如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL占用内存过大如何解决”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

解决方案
了解到可以通过修改配置来减小MySQL的内存占用,便尝试了一下,并进行了记录。由于我同时有两台服务器,一台装的是windows service 2016,还有一台装的是CentOS7,两台情况都是差不多的,故同时做两份记录,供大家参考。

找到配置文件
Windows Service 2016
配置文件的默认位置是C:\ProgramData\MySQL\MySQL Server 8.0\my.ini,如果有修改,则根据自己的实际情况找到。

CentOS7
配置文件的默认路径在/etc/my.cnf,如果有修改,则根据自己的实际情况找到。

修改配置文件
Windows上可以用Ctrl + F 进行搜索,Linux上可以用 ‘/key’ 进行搜索,不会的话可以参考一下百度。

我们需要找到并修改的东西一共有三个:

找到 table_definition_cache,我们修改为400官方解释为:可以存储在定义缓存中的表定义数(来自.frm文件)。如果使用大量表,可以创建大型表定义缓存以加快表的打开速度。与普通的表缓存不同,表定义缓存占用更少的空间,并且不使用文件描述符。最小值和默认值均为400。

找到 table_open_cache,我们修改为256MySQL每打开一个表,都会读入一些数据到table_open_cache缓存中,当MySQL在这个缓存中找不到相应信息时,才会去磁盘上读取。官方解释为:所有线程的打开表数。增加该值会增加mysqld所需的文件描述符的数量。因此,您必须确保在[mysqld safe]部分的变量“open files limit”中将允许打开的文件量设置为至少4096。

找到 performance_schema ,修改为off如果找不到这个的话,直接在合适的地方加上 performance_schema = off 即可。用于监控MySQL server在一个较低级别的运行过程中的资源消耗、资源等待等情况,关闭之后可以节省开销,不会使server的行为发生变化。
修改完之后保存退出。

到此,关于“MySQL占用内存过大如何解决”的学习就结束了,希望能够解决大家的疑惑。

(编辑:拼字网 - 核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章