用tpcc测试对比 innodb 和 tokudb
测试环境 1台IBM Intel(R) Xeon(R) CPU E5606 @ 2.13GHz,内存12G
cd tpcc/tpcc-mysql/src
# make
cc load.o support.o `mysql_config --libs_r` -lrt -o ../tpcc_load
/usr/bin/ld: cannot find -lperconaserverclient
collect2: ld 返回 1
make: *** [../tpcc_load] 错误 1
# vi /etc/ld.so.conf.d/percona-x86_64.conf
/usr/local/percona/lib
# ldconfig -v 可看到
/usr/local/percona/lib:
libHotBackup.so -> libHotBackup.so
libperconaserverclient.so.18 -> libperconaserverclient_r.so.18.1.0
但 make 依然出错
# mysql_config --libs_r 输出
-L/usr/local/percona/lib/mysql -lperconaserverclient -lpthread -lm -lrt -lssl -lcrypto -ldl
/usr/local/percona/lib/mysql 下没有 libperconaserverclient.so 文件,但在 /usr/local/percona/lib 下有,做个链接
# cd /usr/local/percona/lib/mysql
# ln -s ../libperconaserverclient.so libperconaserverclient.so
编译通过了
要对脚本做适当修改,建表 create_table.sql
sed -i 's/Engine=InnoDB/Engine=tokudb/' create_table.sql
add_fkey_idx.sql 删除外建相关语句
load 100库
innodb 8.3G 1小时22分钟
tokudb 6.5G 1小时39分钟
看上去压缩效果并不明显,原因应该是tpcc的模拟数据随机性比较大,重复率低,我们日志库的压缩率就非常明显,是原来的1/8左右。
首次sql执行时间(秒)
select count(*) from customer;
innodb 1.06 tokudb 2.79
调整缓存 innodb 1G tokudb 8G 重启后测tokudb
停机时 InnoDB: Waiting for page_cleaner to finish flushing of buffer pool 花了2,3分钟
io wait 降到10%~20%+
第一次 7023.700 TpmC 第二次
tokudb_row_format = tokudb_uncompressed
第一次 6646.050 TpmC 第二次 7344.450 TpmC
结论:不压缩总体结果并无明显优势
200仓库继续测试,tokudb_row_format = tokudb_fast
tokudb 占用 12G
导入费时 2时46分 加索引费时 35分钟
32并发,预热2分钟,测试20分钟
第一次 4884.400 TpmC 第二次 4735.650 TpmC
64并发
第一次 5333.250 TpmC
|
总仓库数 |
压测仓库数 |
缓存 GB |
禁用系统缓存 |
并发 连接数 |
TpmC 第1次 |
TpmC 第2次 |
|
|
tokudb |
100 |
100 |
4 |
否 |
32 |
1719.300 |
|
|
Innodb |
100 |
100 |
4 |
否 |
32 |
1531.000 |
|
|
+12.30% |
|||||||
|
tokudb |
100 |
100 |
4 |
否 |
64 |
2182.650 |
|
|
Innodb |
100 |
100 |
4 |
否 |
64 |
2322.500 |
|
|
-6.02% |
|||||||
|
tokudb |
200 |
100 |
10 |
是 |
64 |
6481.750 |
|
|
Innodb |
200 |
100 |
10 |
是 |
64 |
3199.000 |
|
|
+102.62% |
|||||||
|
tokudb |
200 |
200 |
10 |
是 |
64 |
2683.150 |
|
|
Innodb |
200 |
200 |
10 |
是 |
64 |
1206.750 |
|
|
+122.35% |
|||||||
|
tokudb |
400 |
400 |
10 |
是 |
64 |
953.900 |
1047.800 |
|
Innodb |
400 |
400 |
10 |
是 |
64 |
311.200 |
498.950 |
|
+207% |
+110% |
||||||
|
tokudb |
400 |
200 |
10 |
是 |
64 |
2981.900 |
2745.450 |
|
Innodb |
400 |
200 |
10 |
是 |
64 |
851.300 |
1992.200 |
|
+250% |
+38% |
||||||
|
tokudb |
400 |
200 |
8 |
是 |
64 |
1889.500 |
|
|
tokudb |
400 |
200 |
4 |
是 |
64 |
1452.100 |
|
|
tokudb |
400 |
200 |
1 |
是 |
64 |
551.700 |
注:预热时间2分钟,压测时间20分钟,压测结果均符合要求;
总体结论:tokudb推荐用压缩数据,性能比innodb好,在数据量大的情况下表现更明显。
linux禁用文件缓存:# echo 1 > /proc/sys/vm/drop_caches
用tpcc测试对比 innodb 和 tokudb的更多相关文章
- 【原创】oracle的tpc-c测试及方法
大家好,很高兴来到博客园分享自己的所见所得.希望和大家多多交流,共同进步. 本文重点在于简介使用BenchmarkSQL对oracle进行tpcc的测试步骤,只是一个简单入门的过程. 开源测试工具:B ...
- QT5.1.0,QT4.8.0以及VC2010、VC2012的测试对比
QT5.1.0,QT4.8.0以及VC2010.VC2012的交叉测试对比. 测试1: 用VC2012静态编译了QT5.1.0. 编译速度很慢,生成完成后,用VC2012+QT5.1.0进行程序生成, ...
- Oracle的TPCC测试,原来也是个作弊的东西...
http://www.oaktable.net/content/sorted-hash-clusters-rip 根据Jonathan Lewis老先生的测试实例,发觉cluster 的sort功能, ...
- tpcc-mysql 系列二:进行TPCC测试
1:开始测试 tpcc_start -h server_host -P port -d database_name -u mysql_user \ -p mysql_password -w wareh ...
- TPC-C测试
TPC发布的测试标准之一,是专门针对联机事务处理系统(OLTP)的测试标准.1992年发布1.0版本.最新版本5.11,2010年发布. 测试规范中模拟了一个比较复杂并具有代表意义的OLTP应用环境, ...
- Linux下几种常见压缩方式测试对比
目录 Linux下几种常见压缩方式测试对比 参考 简介 测试 总结 Linux下几种常见压缩方式测试对比
- [转帖]TPC-C解析系列02_OceanBase如何做TPC-C测试
TPC-C解析系列02_OceanBase如何做TPC-C测试 http://www.itpub.net/2019/10/08/3333/ 导语: 蚂蚁金服自研数据库OceanBase登顶TPC- ...
- 主流存储引擎详解:Innodb,Tokudb、Memory、MYISAM、Federated
主流存储引擎: Innodb:推荐使用,主力引擎,使用99%以上的场景 Tokudb:高速写入使用,日用量大量写入eg:500G可压缩为50G.适用于访问日志的写入,相对MYISAM有事务性,相对于I ...
- TF卡速度测试对比 Class数越高速度越快
存储卡(TF卡)是手机扩展存储的大杀器,让你多装n部学习资料,多装n个外语听力练习.除了装东西外,存储卡性能不佳也会影响手机的整体性能以及体验的.本文主要针对Android手机,我是懒人,但我讨厌懒人 ...
随机推荐
- ACM-东北大学程序设计竞赛-网络赛(2016.04.16)
Problem: A Time limit: 1s Mem limit: 64 MB AC/Submission: 0/0 Discuss Back Ranklist Stat ...
- (十四)WebGIS中地图放大缩小的设计和实现
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 在上一章中,我们给出了整个工具栏设计的核心,使用命令模式,并 ...
- Android测试提升效率批处理脚本
前言: APP测试过程中,经常需要用的一些命令,如adb,每次敲命令,虽可以加深印象,但个人认为那即繁琐又浪费时间.本文贴出一些我使用的批处理,以及一点点小小技巧. 目录 1.[查看APK文件信息.b ...
- jQuery-1.9.1源码分析系列(六) 延时对象续——辅助函数jQuery.when
$.when的说明 描述: 提供一种方法来执行一个或多个对象的回调函数,返回这些对象的延时(Deferred)对象. 说明(结合实例和源码): 如果你不传递任何参数, jQuery.when()将返 ...
- EF 的 霸气配置,秒杀一切
通过EF 作为操作数据库的工具有一段时间了,也做了几个相对不大的项目,慢慢的也对EF的使用摸索出来了一些规则,虽然说不是技术难点,但是,我说的是但是,能够提高我们开发效率的棉花糖有时我们还是必须要吃的 ...
- jquery easyui使用(三)······datagrid加载数据(已解决)
<div id="table_Data"> </div> $("#table_Data").datagrid({ toolbar: '# ...
- div+css页面右侧底部悬浮层
效果体验:http://hovertree.com/texiao/css/23/ 效果图: 代码如下: <!DOCTYPE html> <html> <head> ...
- js补充小知识点(continue,break,ruturn)
1.continue,break,ruturn eg:1-100的和 $(function () { $("#hello").click(function () { var iNu ...
- Java的HTTP通信
在Android中,HTTP通信可以用Volley,在Java中不能使用Volley,只能使用DefaultHttpClient,HttpPost和HttpResponse. /* * 向服务器发送数 ...
- 【工业串口和网络软件通讯平台(SuperIO)教程】六.二次开发导出数据驱动
SuperIO相关资料下载:http://pan.baidu.com/s/1pJ7lZWf 1.1 导出数据接口的作用 在数据集成系统项目中,要么是自已集成其他厂家的设备,要么是其他厂家集成自己 ...