当前位置:网站首页>MySQL占用内存过大解决方案
MySQL占用内存过大解决方案
2022-07-06 09:17:00 【阿杆.】
前言
对于部分小资玩家来说,服务器数量和内存往往是很有限的,像我个人的服务器配置就是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,我们修改为256MySQL每打开一个表,都会读入一些数据到table_open_cache缓存中,当MySQL在这个缓存中找不到相应信息时,才会去磁盘上读取。
官方解释为:所有线程的打开表数。增加该值会增加mysqld所需的文件描述符的数量。因此,您必须确保在[mysqld safe]部分的变量“open files limit”中将允许打开的文件量设置为至少4096。
找到
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的内存占用,但我这只是通过降低性能来换取内存罢了,如果对吞吐量要求比较高的情况,那肯定是不能这样直接修改的,得根据实际请求进行调整才行。
边栏推荐
- Reno7 60W super flash charging architecture
- RT-Thread的main线程“卡死”的一种可能原因及解决方案
- Use of lists
- 电商数据分析--薪资预测(线性回归)
- C语言,log打印文件名、函数名、行号、日期时间
- MySQL realizes read-write separation
- STM32 how to locate the code segment that causes hard fault
- Amba, ahb, APB, Axi Understanding
- Kaggle竞赛-Two Sigma Connect: Rental Listing Inquiries(XGBoost)
- 【ESP32学习-2】esp32地址映射
猜你喜欢

IOT system framework learning

Togglebutton realizes the effect of switching lights

open-mmlab labelImg mmdetection
![[esp32 learning-2] esp32 address mapping](/img/ee/c4aa0f7aed7543bb6807d7fd852c88.png)
[esp32 learning-2] esp32 address mapping

物联网系统框架学习

RT-Thread API参考手册

AMBA、AHB、APB、AXI的理解

Oppo vooc fast charging circuit and protocol

Kaggle competition two Sigma connect: rental listing inquiries

荣耀Magic 3Pro 充电架构分析
随机推荐
5G工作原理详解(解释&图解)
机器学习--线性回归(sklearn)
R & D thinking 01 ----- classic of embedded intelligent product development process
Gallery之图片浏览、组件学习
Arm pc=pc+8 is the most understandable explanation
C语言函数之可变参数原理:va_start、va_arg及va_end
VSCode基础配置
Distribute wxWidgets application
ESP学习问题记录
ESP learning problem record
Detailed explanation of 5g working principle (explanation & illustration)
Programmers can make mistakes. Basic pointers and arrays of C language
Contiki源码+原理+功能+编程+移植+驱动+网络(转)
OSPF message details - LSA overview
Keyword inline (inline function) usage analysis [C language]
Cannot change version of project facet Dynamic Web Module to 2.3.
小天才电话手表 Z3工作原理
Apprentissage automatique - - régression linéaire (sklearn)
Kaggle competition two Sigma connect: rental listing inquiries (xgboost)
ESP8266通过Arduino IDE连接Onenet云平台(MQTT)