【原创】MySQL5.7.18(ptmalloc VS tcmalloc VS jemalloc)性能测试
ptmalloc(glibc的malloc)是Linux提供的内存分配管理模块,目前我们MySQL默认使用的内存分配模块。
tcmalloc是Google提供的内存分配管理模块。
jemalloc是FreeBSD提供的内存分配管理模块。
下面用sysbench对MySQL5.7.18搭配三种不同的内存分配管理模块做了压测。
【sysbench配置】
16个tables,单表数据量2500W,OLAP模式,预热时间600S,单次测试时间600S,每个场景测试5次。
【mysql配置】
关闭预热,buffer pool调整为16G,服务器物理内存64G
innodb_buffer_pool_load_at_startup=0
innodb_buffer_pool_size=16G
【测试数据】
|
QPS |
ptmalloc2 |
tcmalloc4.1.0 |
jemalloc-5.0.1 |
|
warm up |
8158.05 |
8720.78 |
8828.06 |
|
Threads 16 |
8788.19 |
8755.96 |
9976.9 |
|
Threads 32 |
13481.61 |
11908.99 |
13559.32 |
|
Threads 64 |
15722.35 |
15678.27 |
17015.05 |
|
Threads 128 |
17957.68 |
17929.17 |
19665.71 |
|
TPS |
ptmalloc2 |
tcmalloc4.1.0 |
jemalloc-5.0.1 |
|
warm up |
453.22 |
484.47 |
490.44 |
|
Threads 16 |
488.21 |
486.43 |
554.25 |
|
Threads 32 |
748.96 |
661.59 |
753.28 |
|
Threads 64 |
873.43 |
870.99 |
945.24 |
|
Threads 128 |
997.57 |
996.02 |
1092.42 |
|
ptmalloc |
tcmalloc |
jemalloc |
|
|
VmRSS: |
2259272 |
2325520 |
2899384 |
|
VmRSS: |
4942224 |
4205684 |
3990556 |
|
VmRSS: |
7351488 |
6668696 |
6585080 |
|
VmRSS: |
9703240 |
9031616 |
9027632 |
|
VmRSS: |
12005820 |
11318512 |
11479836 |
|
VmRSS: |
14261672 |
13639416 |
13845412 |
|
VmRSS: |
16467972 |
15919476 |
16175976 |
|
VmRSS: |
18358520 |
18111000 |
18443324 |
|
VmRSS: |
18366840 |
18403856 |
18649424 |
|
VmRSS: |
18368820 |
18404236 |
18650740 |
|
VmRSS: |
18368504 |
18406144 |
18650896 |
|
VmRSS: |
18467844 |
18492448 |
18718692 |
|
VmRSS: |
18469004 |
18492880 |
18719844 |
|
VmRSS: |
18469268 |
18493016 |
18720412 |
|
VmRSS: |
18469796 |
18493568 |
18721692 |
【图形展示】



【结论】
1、jemalloc在多线程高并发环境下,随着并发线程数的增加,QPS和TPS增长比较稳定,性能高于ptmalloc和tcmalloc。
2、在目前的压测场景下,随着线程数的增加,MySQL进程占用的物理内存并没有太大的差异。
3、关于jemalloc的应用,相对tcmalloc而言,jemalloc是MariaDB,Redis等默认的内存分配管理模块,另外AliSQL也集成了jemalloc。
【附录】
1、下图是其他机构的一个测试报告(针对较早之前的版本),最左边的是glibc的ptmalloc,最右边的就是jemalloc,
可以看到jemalloc和tcmalloc的性能差异不大,jemalloc的效率稍高。

2、三者的比较
|
ptmalloc2 |
tcmalloc4.1.0 |
jemalloc-5.0.1 |
|
ptmalloc的缺陷
|
tcmalloc的改进
|
jemalloc的优化
|
参考资料:
ptmalloc,tcmalloc和jemalloc内存分配策略研究
http://www.360doc.com/content/13/0915/09/8363527_314549128.shtml
内存优化总结:ptmalloc、tcmalloc和jemalloc
http://www.cnhalo.net/2016/06/13/memory-optimize/

【原创】MySQL5.7.18(ptmalloc VS tcmalloc VS jemalloc)性能测试的更多相关文章
- ptmalloc、tcmalloc和jemalloc
内存优化总结:ptmalloc.tcmalloc和jemalloc 转载 2017年09月05日 18:57:12 3674 转载于:http://www.cnhalo.net/2016/06/13/ ...
- 内存优化总结:ptmalloc、tcmalloc和jemalloc(转)
转载于:http://www.cnhalo.net/2016/06/13/memory-optimize/ 概述 需求 系统的物理内存是有限的,而对内存的需求是变化的, 程序的动态性越强,内存管理就越 ...
- 内存优化总结:ptmalloc、tcmalloc和jemalloc
概述 需求 系统的物理内存是有限的,而对内存的需求是变化的, 程序的动态性越强,内存管理就越重要,选择合适的内存管理算法会带来明显的性能提升.比如nginx, 它在每个连接accept后会malloc ...
- Apache2.4.23+PHP5.6.30+MySQL5.7.18安装教程
最近在工作中常常接触到PHP,自己也写过一些简单的PHP页面.我们知道PHP是在服务器端运行的脚本语言,因此我们需要配置服务器环境.之前为了省事直接使用的是wamp集成环境,但是突然某一天领导要求我们 ...
- mac下,mysql5.7.18连接出错,错误信息为:Access denied for user 'root'@'localhost' (using password: YES)
mac下,mysql5.7.18连接出错,错误信息为:Access denied for user 'root'@'localhost' (using password: YES)()里面的为shel ...
- mysql5.7.18的安装与主从复制
CentOS6.7安装mysql5.7.18 1. 解压到/usr/local目录 # tar -zxvf mysql-5.7.18-linux-glibc2.5-i686.tar.gz -C /u ...
- Centos7.3下mysql5.7.18安装并修改初始密码的方法
Centos7.3下mysql5.7.18安装并修改初始密码的方法 原文链接:http://www.jb51.net/article/116032.htm 作者:Javen205 字体:[增加 减小] ...
- windows10下 MySQL5.7.18版本安装过程及遇到的问题
windows10下 MySQL5.7.18版本安装过程及遇到的问题 mysql-5.7.18-winx64 安装 1.解压 此次将MySQL装在H盘,依个人喜 ...
- Windows下安装MySQL5.7.18的方法
准备: 操作系统:win7 下64位的zip版本的MySQL,路径:http://dev.mysql.com/downloads/mysql/ 我下的是最新版的MySQL,解压后,目录如下: 可以看到 ...
随机推荐
- 打包python脚本为exe的坎坷经历, by pyinstaller方法
打包python脚本为exe的坎坷经历, by pyinstaller方法 又应验了那句歌词. 不经历风雨, 怎么见得了彩虹. 安装过程略去不提, 仅提示: pip install pyinstall ...
- Postgresql数据库安装中文全文搜索插件zhparser的问题
在PG数据库的基础上加装zhparser中文全文搜索插件,说实话,挺怕这些单独编译安装的插件的,因为安装PG数据库方法的不同,最后可能导致安装的插件各种安装不上,这里说一下我遇到的坑,系统环境是Cen ...
- 博主退役了qwq
noip靠太差的(蒟蒻)博主退役了qwq 感觉以后都没什么机会可以继续写博客了 这个博客八成是坟了呀qwq 其实感觉也没有什么人关注qwq 所以也不长篇大论些什么了 就这样吧qwq
- 适配器在JavaScript中的体现
适配器设计模式在JavaScript中非常有用,在处理跨浏览器兼容问题.整合多个第三方SDK的调用,都可以看到它的身影. 其实在日常开发中,很多时候会不经意间写出符合某种设计模式的代码,毕竟设计模式就 ...
- TCP检验和
TCP的检验和 检验和目的 目的是为了发现TCP首部和数据在发送端到接收端之间发生的任何改动.如果接收方检测到检验和有差错,则TCP段会被直接丢弃. TCP在计算检验和时,要加上一个12字节的伪首 ...
- fc26 url
aarch64 http://linux.yz.yamagata-u.ac.jp/pub/linux/fedora-projects/fedora-secondary/releases/26/Ever ...
- MySQL GTID你知多少【转】
MySQL在5.6的版本推出了GTID复制,相比传统的复制,GTID复制对于运维更加友好,这个事务是谁产⽣,产⽣多少事务,⾮常直接的标识出来,当然GTID也有限制,对于什么是GTID可以参考我之前的文 ...
- C#.NET调用WSDL接口及方法
1.首先需要清楚WSDL的引用地址 如:http://XX.XX.4.146:8089/axis/services/getfileno?wsdl 上述地址的构造为 类名getfileno. 2.在.N ...
- docker安装(2018-03-14版本)
[安装] 说明一: CENTOS或RHEL自带的docker源不一定是最新的,所以必须到docker.com去找到最新的yum源进行安装 说明二: docker的安装方式有两种: 1. 从指定网站获取 ...
- 从一份配置清单详解 Nginx 服务器配置
概述 在前面< Nginx 服务器开箱体验> 一文中我们从开箱到体验,感受了一下 Nginx 服务器的魅力.Nginx 是轻量级的高性能 Web 服务器,提供了诸如 HTTP 代理和反 ...