共计 1474 个字符,预计需要花费 4 分钟才能阅读完成。
这篇文章主要介绍“MySQL 占用内存过大如何解决”,在日常操作中,相信很多人在 MySQL 占用内存过大如何解决问题上存在疑惑,丸趣 TV 小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL 占用内存过大如何解决”的疑惑有所帮助!接下来,请跟着丸趣 TV 小编一起来学习吧!
前言
对于部分小资玩家来说,服务器数量和内存往往是很有限的,像我个人的服务器配置就是 2 核 4G5M。
4G 内存对于 Java 玩家来说,真的不大,开几个中间件 + 自己的微服务真的还蛮挤的,然后又摊上 MySQL 这个大冤种。我本机上的 MySQL 仅仅只占几 M 内存(虽然我不怎么用,但是本机 MySQL 确实是开着的):
而服务器的则要占 400M,怎么说其实没什么吞吐量,纯粹是自己玩一玩,这内存占用属实有点吃不消啊。。。
解决方案
了解到可以通过修改配置来减小 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,我们修改为 256
MySQL 每打开一个表,都会读入一些数据到 table_open_cache 缓存中,当 MySQL 在这个缓存中找不到相应信息时,才会去磁盘上读取。
官方解释为:所有线程的打开表数。增加该值会增加 mysqld 所需的文件描述符的数量。因此,您必须确保在 [mysqld safe] 部分的变量“open files limit”中将允许打开的文件量设置为至少 4096。
找到 performance_schema,修改为 off
如果找不到这个的话,直接在合适的地方加上 performance_schema = off 即可。
用于监控 MySQL server 在一个较低级别的运行过程中的资源消耗、资源等待等情况,关闭之后可以节省开销,不会使 server 的行为发生变化。
修改完之后保存退出。
重启 MySQLWindows Service 2016
以管理员身份启动控制台,输入 net stop mysql,然后再输入 net start mysql。
重启之后还占 62M。
CentOS7
控制台输入 service mysqld restart 即可重启。
如果不行的话,可以试试 /etc/init.d/mysqld restart 这个指令。
重启之后占用 92M,比 Windows 那台多点。
到此,关于“MySQL 占用内存过大如何解决”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注丸趣 TV 网站,丸趣 TV 小编会继续努力为大家带来更多实用的文章!