减少 mysql 内存占用
小站点的服务器一般在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
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦