减少 mysql 内存占用

  • 2020-12-23
  • 浏览 (1627)

小站点的服务器一般在512M或1G左右,但是我们安装的MySQL 5.6、5.7默认启动占用内存400多M,MySQL内存占用率明显偏高,将会导致MySQL崩溃,经常出现 MySQL 自动停止的情况。mysql 的使用内存可以优化的。主要有两种方法:关闭performance_schema和调整msyql的参数。

关闭 performance_schema

MySQL 5.5开始新增一个数据库:PERFORMANCE_SCHEMA,主要用于收集数据库服务器性能参数。并且库里表的存储引擎均为PERFORMANCE_SCHEMA,而用户是不能创建存储引擎为PERFORMANCE_SCHEMA的表。MySQL5.5默认是关闭的,需要手动开启,在配置文件里添加:

[mysqld]
performance_schema=ON

从MySQL5.6开始,默认打开,本文就从MySQL5.6来说明,在数据库使用当中PERFORMANCE_SCHEMA的一些比较常用的功能。具体的信息可以查看官方文档

查看是否开启

mysql>show variables like 'performance_schema';
+--------------------+-------+
| Variable_name      | Value |
+--------------------+-------+
| performance_schema | ON    |
+--------------------+-------+

查看performance_schema开启时mysql占用的内存

ps aux | grep mysqld | grep -v grep | awk '{print $11 "\t" $6/1024"MB" }'

结果:

mysqld	557.254MB

关闭 performance_schema

查看mysql启动时读取配置文件的默认目录

mysql --help|grep 'my.cnf'

在mysql.cnf添加配置:

[mysqld]
performance_schema = off 

重启mysql,查看关闭performance_schema后占用的内存:

ps aux | grep mysqld | grep -v grep | awk '{print $11 "\t" $6/1024"MB" }'

结果

mysqld	515.32MB

可以看到内存少了大概40M。

调整参数

修改 /etc/mysql/mysql.conf.d/mysqld.cnf,在配置末尾追加如下配置

performance_schema_max_table_instances=150
table_definition_cache=150
table_open_cache=64
innodb_buffer_pool_size=2M

5.6默认的设置

performance_schema_max_table_instances = 12500
table_definition_cache = 1400
table_open_cache = 2000
innodb_buffer_pool_size=128M

查看占用内存:

mysqld	171.859MB

减少了400M哦,效果明显。

0  赞