减少mysql内存_减少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哦,效果明显。
减少mysql内存_减少mysql内存占用相关推荐
- mysql数据库映射到内存_基于共享内存的数据库映射
基于共享内存的数据库映射 概述 随着各类行业软件对性能追求越来越高,因此对数据库处理的速度提出了新的挑战.然而大部分复杂的业务处理往往依赖体量较大的关系数据(如:Oracle,Mysql,Postgr ...
- mysql56 配置内存_【mysql】mysql 内存配置调优
mysql的内存计算公式: mysql used mem = key_buffer_size + query_cache_size + tmp_table_size + innodb_buffer_p ...
- 简易mysql优化_优化 MySQL:简单三个技巧
原标题:优化 MySQL:简单三个技巧 技巧#1:为临时表分配足够的内存 在某些情况下,服务器在处理语句时会创建内部临时表.临时表用于内部操作如GROUP BY和distinct,还有一些ORDER ...
- java代码耗尽内存_有关Java内存溢出及内存消耗的小知识
内存溢出原理: 我们知道,Java程序本身是不能直接在计算机上运行的,它需要依赖于硬件基础之上的操作系统和JVM(Java虚拟机). Java程序启动时JVM都会分配一个初始内存和最大内存给这个应用程 ...
- linux查看内存_嵌入式操作系统的内存,你了解多少?
关注.星标公众号,不错过精彩内容 来源:EDN电子技术设计 linux 内存是后台开发人员,需要深入了解的计算机资源.合理的使用内存,有助于提升机器的性能和稳定性.本文主要介绍 linux 内存组织结 ...
- mysql整备_【mysql】使用xtrabackup在线增量备份及恢复数据库
一.Percona Xtrabackup 简介 1.Xtrabackup bin目录文件 介绍 1)innobackupex innobackupex 是xtrabackup的一个符号链接 . in ...
- mysql 优化_常用MySQL优化
1.大批量插入数据优化 (1)对于MyISAM存储引擎的表,可以使用:DISABLE KEYS 和 ENABLE KEYS 用来打开或者关闭 MyISAM 表非唯一索引的更新. ALTER TABLE ...
- nginx内存池大小快内存_使用直接内存时可以更快
nginx内存池大小快内存 总览 使用直接内存不能保证提高性能. 考虑到它增加了复杂性,除非有充分的理由使用它,否则应避免使用它. 塞尔吉奥·奥利维拉(Sergio Oliveira Jr)的这篇出色 ...
- 建立唯一索引后mysql策略_【MySQL】MySQL索引背后的之使用策略及优化【转】
另外很不错的对于索引及索引优化的文章: 索引的使用 示例数据库 为了讨论索引策略,需要一个数据量不算小的数据库作为示例.本文选用MySQL官方文档中提供的示例数据库之一:employees.这个数据库 ...
最新文章
- Java中类、常量、变量、方法名等命名规则
- 正则替换文章图片路径,并跳过远程连接的图片
- 二进制搭建kubernetes多master集群【三、配置k8s master及高可用】
- boost::mp11::mp_join相关用法的测试程序
- Jquery 点击当前的标签对象获取值 与JS整理
- 南京理工大学计算机学院教授严捍,2019年7月1日学术报告二则(宋巍 教授,南京理工大学;张鹏程 副教授,河海大学)...
- python snmp 自动化2-在python中使用snmp
- python数据分类聚类案例_Python 数据分类与聚类分析(5)
- Python机器学习——概念及其物理解释
- SI9000阻抗计算教程
- 数据库系统概念第六版
- Scrapy-2:东莞阳光政务平台
- tumblr_将您的Tumblr博客与社交网络集成
- java按键机nes模拟器_NES 模拟器开发教程 12 - 输入设备
- MAC电脑实现微信多开
- 官方指标监控神器SpringBootAdmin保姆级教程
- 钉钉、企业微信、飞书的掘金逻辑
- NRF24L01的使用
- JAVA基础之二维数组三维数组及应用
- The Meaning of Life
热门文章
- mysqldump导出数据表结构
- 中顶母婴用品管理系统
- MySQL数据库三段式_对数据库模式进行规范化处理,是在数据库设计的什么阶段?...
- 阿里P7晒工资条,看完好扎心了……
- nodejs安装cnpm淘宝镜像
- java old gen_java – JVM Tenured/Old gen达到限制和挂载服务器
- WordPress 时光轴响应式Niconiconi主题
- 【100%通过率】华为OD机试真题 JavaScript 实现【字符串解密】【2023 Q1 | 100分】
- 深度学习常用激活函数
- 韩国服务器稳定怎么解决,韩国服务器不稳定怎么办