• 技术文章 >数据库 >mysql教程

    实例详解MySQL占用内存过大解决方法

    长期闲置长期闲置2022-07-06 14:03:51转载128
    本篇文章给大家带来了关于mysql的相关知识,其中主要整理了占用内存过大解决方法的相关问题,分别使用windows和CentOS7两种系统来解决该问题,下面一起来看一下,希望对大家有帮助。

    推荐学习:mysql视频教程

    前言

    对于部分小资玩家来说,服务器数量和内存往往是很有限的,像我个人的服务器配置就是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’ 进行搜索,不会的话可以参考一下百度。

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

    1. 找到 table_definition_cache,我们修改为400

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

    2. 找到 table_open_cache,我们修改为256

      MySQL每打开一个表,都会读入一些数据到table_open_cache缓存中,当MySQL在这个缓存中找不到相应信息时,才会去磁盘上读取。

      官方解释为:所有线程的打开表数。增加该值会增加mysqld所需的文件描述符的数量。因此,您必须确保在[mysqld safe]部分的变量“open files limit”中将允许打开的文件量设置为至少4096。

    3. 找到 performance_schema ,修改为off

      如果找不到这个的话,直接在合适的地方加上 performance_schema = off 即可。

      用于监控MySQL server在一个较低级别的运行过程中的资源消耗、资源等待等情况,关闭之后可以节省开销,不会使server的行为发生变化。

    修改完之后保存退出。

    重启MySQL

    Windows Service 2016

    以管理员身份启动控制台,输入 net stop mysql,然后再输入 net start mysql。

    重启之后还占62M。

    在这里插入图片描述

    CentOS7

    控制台输入 service mysqld restart 即可重启。

    在这里插入图片描述

    如果不行的话,可以试试 /etc/init.d/mysqld restart 这个指令。

    重启之后占用92M,比Windows那台多点。

    在这里插入图片描述

    后记

    通过这种方法确实可以降低mysql的内存占用,但我这只是通过降低性能来换取内存罢了,如果对吞吐量要求比较高的情况,那肯定是不能这样直接修改的,得根据实际请求进行调整才行。

    推荐学习:mysql视频教程

    以上就是实例详解MySQL占用内存过大解决方法的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:CSDN,如有侵犯,请联系admin@php.cn删除
    专题推荐:mysql
    上一篇:数据库中增加一条新数据使用的命令是什么 下一篇:聊聊MySQL的基础架构和日志系统
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• MySQL学习之一条SQL是如何执行的?聊聊执行流程• MySQL约束与多表查询基础详解• 深入解析mysql中的索引(原理详解)• mysql远程连接不上怎么办• MySQL怎么解决delete大量数据后空间不释放的问题
    1/1

    PHP中文网