首页 / MYSQL / 为什么MySQL会消耗大量内存?
为什么MySQL会消耗大量内存?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了为什么MySQL会消耗大量内存?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2406字,纯文字阅读大概需要4分钟。
内容图文
![为什么MySQL会消耗大量内存?](/upload/InfoBanner/zyjiaocheng/886/2188acd5009e4b9988583f746486c261.jpg)
我有mysql 5.6.36数据库,其大小是?35G,在带有48G RAM的CentOS 7.3上运行.
[UPDATE 17-08-06]我将更新相关信息here.
我看到我的服务器内存不足,即使有?48G的RAM也崩溃了.例如,我无法使其在24G上运行.如此大小的数据库应该可以运行更少的数据.显然,我缺少基本的东西.
[UPDATE:17-08-05]崩溃是指mysqld停止并重新启动,日志中没有有用的信息,除了从崩溃中重新启动.另外,有了所有这些内存,我在恢复期间遇到了这个错误:
[ERROR] InnoDB: space header page consists of zero bytes in tablespace ./ca_uim/t_qos_snapshot.ibd (table ca_uim/t_qos_snapshot)
我的配置文件的相关部分如下所示[编辑为08-08-05添加缺少的行]:
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
lower_case_table_names = 1
symbolic-links=0
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
max_allowed_packet = 32M
max_connections = 300
table_definition_cache=2000
innodb_buffer_pool_size = 18G
innodb_buffer_pool_instances = 9
innodb_log_file_size = 1G
innodb_file_per_table=1
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
每个表使用文件是一个疏忽,我需要更改它(我有6000个表,其中大多数是分区的).
运行一小段时间(一个小时)后,mytop显示以下内容:
MySQL on 10.238.40.209 (5.6.36) load 0.95 1.08 1.01 1/1003 8525 up 0+01:31:01 [17:44:39]
Queries: 1.5M qps: 283 Slow: 22.0 Se/In/Up/De(%): 50/07/09/01
Sorts: 27 qps now: 706 Slow qps: 0.0 Threads: 118 ( 3/ 2) 43/28/01/00
Key Efficiency: 100.0% Bps in/out: 76.7k/176.8k Now in/out: 144.3k/292.1k
免费显示:
# free -h
total used free shared buff/cache available
Mem: 47G 40G 1.5G 8.1M 5.1G 6.1G
Swap: 3.9G 508K 3.9G
顶部显示此:
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
2010 mysql 20 0 45.624g 0.039t 9008 S 95.0 84.4 62:31.93 mysqld
怎么会这样?每个表格都有这个相关文件吗?整个数据库可以容纳在内存中.我究竟做错了什么?
解决方法:
好吧,我解决了这个问题.我感谢所有回应者的见解.解决方案非常奇怪,我无法解释为什么它可以解决问题,但是确实可以.我所做的是将以下行添加到my.cnf中:
log_bin
此外,您可能还需要添加以下内容:
expire_logs_days = <some number>
我们已经看到至少一个实例,其中日志累积并填满了磁盘.默认值为0(不自动删除). https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_expire_logs_days
内容总结
以上是互联网集市为您收集整理的为什么MySQL会消耗大量内存?全部内容,希望文章能够帮你解决为什么MySQL会消耗大量内存?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。