建站极客
数据库 Mysql 正文
mysql Out of memory (Needed 16777224 bytes)的错误解决
所属分类:
数据库 / Mysql
阅读数:
1967
收藏 0
赞 0
分享
这几天碰到这个错误。 至于我改的这几个值是不是正确的解决方法,目前还不知道。先贴出来。 如果过一段时间我还是没有更新,那以后同志们都参考吧 。 Out of memory (Needed 16777224 bytes)的错误解决 看看手册: [url]http://dev.mysql.com/doc/refman/5.1/en/memory-storage-engine.html[/url] 开始我更改了query_cache_size的值。 好像也不行。 之后 增大query_cache_limit 的值。 还有max_heap_table_size 和tmp_table_size的值。 因为我们的存储过程中用了好多的预处理语句。而且语句的结果都是非常大的。 起初我的结果: mysql> show variables like 'max_heap_table_size'; +---------------------------------+----------------------+ | Variable_name | Value | +---------------------------------+----------------------+ | max_heap_table_size | 16777216 | +---------------------------------+----------------------+ mysql> show variables like 'tmp_table_size'; +---------------------------------+----------------------+ | Variable_name | Value | +---------------------------------+----------------------+ | tmp_table_size | 16777216 | +---------------------------------+----------------------+ 我改了my.cnf文件 mysql> show variables like 'max_heap_table_size'; +---------------------------------+----------------------+ | Variable_name | Value | +---------------------------------+----------------------+ | max_heap_table_size | 67108864 | +---------------------------------+----------------------+ mysql> show variables like 'tmp_table_size'; +---------------------------------+----------------------+ | Variable_name | Value | +---------------------------------+----------------------+ | tmp_table_size | 67108864 | +---------------------------------+----------------------+ 顺便看一下这篇文章中的一段话: http://dev.mysql.com/tech-resources/articles/mysql-query-cache.html Qcache_hits and Qcache_inserts shows the number of times a query was serviced from the cache and how many queries have been inserted into the cache. Low ratios of hits to inserts indicate little query reuse or a too-low setting of the query_cache_limit, which serves to govern the RAM devoted to each individual query cache entry. Large query result sets will require larger settings of this variable. 补充: 今天在手册上看到这段话 http://dev.mysql.com/doc/refman/5.1/en/out-of-memory.html If you issue a query using the mysql client program and receive an error like the following one, it means that mysql does not have enough memory to store the entire query result: 所以我把我的所有存储过程都修改了。 因为里面的预处理语句没有清零。 经过测试。 比如: 里面用到 PREPARE S1 FROM @STMT; ... 一定要 SET @STMT = ''; 不知道这个是不是根本原因。我会再次更新的。 再次证明这样做会减少这种情况。不过下午把所有存储过程修改了。 凡是普通连接的都改为LEFT JOIN 了。通过EXPLAIN建立了相关索引。 而且把版本换成了5.0.45。至于是否还是出现错误。还在继续关注中。。。目前没有任何错误。 这个问题貌似MYSQL官方解决了。 http://bugs.mysql.com/bug.php?id=31898
微信公众平台开发 数据库操作 这篇文章主要介绍了微信公众平台开发 数据库操作的相关资料,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
MySQL redo死锁问题排查及解决过程分析 被告知在多实例场景下 MySQL Server hang 住,无法测试下去,原生版本不存在这个问题,而新版本上出现了这个问题,不禁心头一颤,心中不禁感到奇怪,还好现场环境还在,为排查问题提供了一个好的环境,随即便投入到紧张的问题排查过程当中
评论 0
收藏 0
赞 0
分享
MYSQL GROUP BY用法详解 这篇文章主要为大家详细介绍了MYSQL GROUP BY用法,具有一定的实用性和参考价值,感兴趣的小伙伴们可以参考一下
评论 0
收藏 0
赞 0
分享
mysql如何查询两个日期之间最大的连续登录天数 在现在的很多网站中都有这样一个功能。记录用户的连续登陆天数,所谓的连续在线是指相邻两天都登录过,不一定一直在线,但是只要有过登录即可。这篇文章主要介绍的是利用sql语句如何查询在两个日期之间最大的连续登录天数,有需要的朋友们下面来一起看看吧。
评论 0
收藏 0
赞 0
分享
查看更多