小站点的服务器一般在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哦,效果明显。

减少mysql内存_减少mysql内存占用相关推荐

  1. mysql数据库映射到内存_基于共享内存的数据库映射

    基于共享内存的数据库映射 概述 随着各类行业软件对性能追求越来越高,因此对数据库处理的速度提出了新的挑战.然而大部分复杂的业务处理往往依赖体量较大的关系数据(如:Oracle,Mysql,Postgr ...

  2. mysql56 配置内存_【mysql】mysql 内存配置调优

    mysql的内存计算公式: mysql used mem = key_buffer_size + query_cache_size + tmp_table_size + innodb_buffer_p ...

  3. 简易mysql优化_优化 MySQL:简单三个技巧

    原标题:优化 MySQL:简单三个技巧 技巧#1:为临时表分配足够的内存 在某些情况下,服务器在处理语句时会创建内部临时表.临时表用于内部操作如GROUP BY和distinct,还有一些ORDER ...

  4. java代码耗尽内存_有关Java内存溢出及内存消耗的小知识

    内存溢出原理: 我们知道,Java程序本身是不能直接在计算机上运行的,它需要依赖于硬件基础之上的操作系统和JVM(Java虚拟机). Java程序启动时JVM都会分配一个初始内存和最大内存给这个应用程 ...

  5. linux查看内存_嵌入式操作系统的内存,你了解多少?

    关注.星标公众号,不错过精彩内容 来源:EDN电子技术设计 linux 内存是后台开发人员,需要深入了解的计算机资源.合理的使用内存,有助于提升机器的性能和稳定性.本文主要介绍 linux 内存组织结 ...

  6. mysql整备_【mysql】使用xtrabackup在线增量备份及恢复数据库

    一.Percona Xtrabackup 简介 1.Xtrabackup  bin目录文件 介绍 1)innobackupex innobackupex 是xtrabackup的一个符号链接 . in ...

  7. mysql 优化_常用MySQL优化

    1.大批量插入数据优化 (1)对于MyISAM存储引擎的表,可以使用:DISABLE KEYS 和 ENABLE KEYS 用来打开或者关闭 MyISAM 表非唯一索引的更新. ALTER TABLE ...

  8. nginx内存池大小快内存_使用直接内存时可以更快

    nginx内存池大小快内存 总览 使用直接内存不能保证提高性能. 考虑到它增加了复杂性,除非有充分的理由使用它,否则应避免使用它. 塞尔吉奥·奥利维拉(Sergio Oliveira Jr)的这篇出色 ...

  9. 建立唯一索引后mysql策略_【MySQL】MySQL索引背后的之使用策略及优化【转】

    另外很不错的对于索引及索引优化的文章: 索引的使用 示例数据库 为了讨论索引策略,需要一个数据量不算小的数据库作为示例.本文选用MySQL官方文档中提供的示例数据库之一:employees.这个数据库 ...

最新文章

  1. Java中类、常量、变量、方法名等命名规则
  2. 正则替换文章图片路径,并跳过远程连接的图片
  3. 二进制搭建kubernetes多master集群【三、配置k8s master及高可用】
  4. boost::mp11::mp_join相关用法的测试程序
  5. Jquery 点击当前的标签对象获取值 与JS整理
  6. 南京理工大学计算机学院教授严捍,2019年7月1日学术报告二则(宋巍 教授,南京理工大学;张鹏程 副教授,河海大学)...
  7. python snmp 自动化2-在python中使用snmp
  8. python数据分类聚类案例_Python 数据分类与聚类分析(5)
  9. Python机器学习——概念及其物理解释
  10. SI9000阻抗计算教程
  11. 数据库系统概念第六版
  12. Scrapy-2:东莞阳光政务平台
  13. tumblr_将您的Tumblr博客与社交网络集成
  14. java按键机nes模拟器_NES 模拟器开发教程 12 - 输入设备
  15. MAC电脑实现微信多开
  16. 官方指标监控神器SpringBootAdmin保姆级教程
  17. 钉钉、企业微信、飞书的掘金逻辑
  18. NRF24L01的使用
  19. JAVA基础之二维数组三维数组及应用
  20. The Meaning of Life

热门文章

  1. mysqldump导出数据表结构
  2. 中顶母婴用品管理系统
  3. MySQL数据库三段式_对数据库模式进行规范化处理,是在数据库设计的什么阶段?...
  4. 阿里P7晒工资条,看完好扎心了……
  5. nodejs安装cnpm淘宝镜像
  6. java old gen_java – JVM Tenured/Old gen达到限制和挂载服务器
  7. WordPress 时光轴响应式Niconiconi主题
  8. 【100%通过率】华为OD机试真题 JavaScript 实现【字符串解密】【2023 Q1 | 100分】
  9. 深度学习常用激活函数
  10. 韩国服务器稳定怎么解决,韩国服务器不稳定怎么办