Mysql实例mysql Sort aborted: Out of sort memory, consider increasing server sort buffer size的解决方法

Mysql实例mysql Sort aborted: Out of sort memory, consider increasing server sort buffer size的解决方法,第1张

概述介绍《Mysql实例mysql Sort aborted: Out of sort memory, consider increasing server sort buffer size的解决方法》开发教程,希望对您有用。

《MysqL实例MysqL Sort aborted: Out of sort memory,consIDer increasing server sort buffer size的解决方法》要点:
本文介绍了MysqL实例MysqL Sort aborted: Out of sort memory,consIDer increasing server sort buffer size的解决方法,希望对您有用。如果有疑问,可以联系我们。

MysqL应用今天在检查MysqL服务器的时候提示Sort aborted: Out of sort memory,consIDer increasing server sort buffer size,安装字面意思就是 sort内存溢出,考虑增加服务器的排序缓冲区(sort_buffer_size)大小

MysqL应用sort_buffer_size=3M
join_buffer_size = 3M

MysqL应用下面是针对16G 内存设置的参数:

MysqL应用sort_buffer_size = 2M
# Sort_Buffer_Size 是一个connection级参数,在每个connection(session)第一次需要使用这个buffer的时候,一次性分配设置的内存.
#Sort_Buffer_Size 并不是越大越好,由于是connection级的参数,过大的设置+高并发可能会耗尽系统内存资源.例如:500个连接将会消耗 500*sort_buffer_size(8M)=4G内存
#Sort_Buffer_Size 超过2KB的时候,就会使用mmap() 而不是 malloc() 来进行内存分配,导致效率降低.
#技术导读 http://blog.webshuo.com/2011/02/16/MysqL-sort_buffer_size/
#dev-doc: http://dev.MysqL.com/doc/refman/5.5/en/server-parameters.HTML
#explain select*from table where order limit;出现filesort
#属重点优化参数

MysqL应用不过我看到有人将sort_buffer_size设置为10M,我就是因为设置了10M,后来我设置为2-3M,就没有问题了

MysqL应用Written by cenalulu @ 2010-10-26

MysqL应用基础知识:

MysqL应用1、 Sort_Buffer_Size 是一个connection级参数,在每个connection第一次需要使用这个buffer的时候,一次性分配设置的内存.
2、 Sort_Buffer_Size 并不是越大越好,过大的设置+高并发可能会耗尽系统内存资源.
3、 文档说“On linux,there are thresholds of 256KB and 2MB where larger values may significantly slow down memory allocation”

MysqL应用本文主要针对第三点做测试:
据说Sort_Buffer_Size 超过2KB的时候,导致效率降低.

MysqL应用环境:

MysqL应用为了更大的体现性能差距,使用 1GB内存的Fedora 虚拟机进行测试

MysqL应用测试表结构:

MysqL应用1w 行的表,表结构

MysqL应用+-------+------------------+------+-----+---------+----------------+
| FIEld | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| ID    | int(10) unsigned | NO   | PRI | NulL    | auto_increment |
| k     | int(10) unsigned | NO   | Mul | 0       |                |
| c     | char(120)        | NO   |     |         |                |
| pad   | char(60)         | NO   |     |         |                |
+-------+------------------+------+-----+---------+----------------+

MysqL应用测试语句:

MysqL应用分别设置Sort_Buffer_Size 为 250K,512K,3M,然后运行以下语句,查看运行时间.
1. @R_419_6983@_no_cache 防止query cache起效.
2. limit 1 为了减少排序占执行时间的比重,更多的体现内存分配带来的影响
3. 语句explain的结果是 filesort,以确保使用sort_buffer

代码如下:
MysqLslap -uroot -h127.0.0.1 -q ' select @R_419_6983@_no_cache * from sbtest order by pad limit 1' -c 100 --create-schema=test -i 10

MysqL应用测试结果:

MysqL应用执行时间

MysqL应用250K : 1.318s
512K : 1.944s
3M     : 2.412s

MysqL应用250 K
[root@localhost tmp]# MysqLslap -uroot -h127.0.0.1 -q ' select @R_419_6983@_no_cache * from sbtest order by pad limit 1' -c 100 --create-schema=test -i 10
Benchmark
        Average number of seconds to run all querIEs: 1.318 seconds
        Minimum number of seconds to run all querIEs: 1.285 seconds
        Maximum number of seconds to run all querIEs: 1.378 seconds
        Number of clIEnts running querIEs: 100
        Average number of querIEs per clIEnt: 1

MysqL应用512 K

MysqL应用[root@localhost tmp]# MysqLslap -uroot -h127.0.0.1 -q ' select @R_419_6983@_no_cache * from sbtest order by pad limit 1' -c 100 --create-schema=test -i 10
Benchmark
        Average number of seconds to run all querIEs: 1.944 seconds
        Minimum number of seconds to run all querIEs: 1.362 seconds
        Maximum number of seconds to run all querIEs: 4.406 seconds
        Number of clIEnts running querIEs: 100
        Average number of querIEs per clIEnt: 1

MysqL应用3M
[root@localhost tmp]# MysqLslap -uroot -h127.0.0.1 -q ' select @R_419_6983@_no_cache * from sbtest order by pad limit 1' -c 100 --create-schema=test -i 10
Benchmark
        Average number of seconds to run all querIEs: 2.412 seconds
        Minimum number of seconds to run all querIEs: 2.376 seconds
        Maximum number of seconds to run all querIEs: 2.527 seconds
        Number of clIEnts running querIEs: 100
        Average number of querIEs per clIEnt: 1

MysqL应用结论:
确实如文档所说,使用mmap 分配内存时,会带来性能上的损耗,影响大约在 30% 左右.
由于是limit 1,因此减弱了buffer size对排序速度的影响.
其实buffer size 越大,所需要进行的sort-merge的次数越少,执行时间越短.视具体的语句而定.
我只是想说明下,并不是越大越好. 也并不存在一个绝对的最佳值.
还是要看具体的业务环境决定值的大小. 对于高并发的应用,还是别设置太大的比较好.

总结

以上是内存溢出为你收集整理的Mysql实例mysql Sort aborted: Out of sort memory, consider increasing server sort buffer size的解决方法全部内容,希望文章能够帮你解决Mysql实例mysql Sort aborted: Out of sort memory, consider increasing server sort buffer size的解决方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1163208.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存