当前位置:首页 > 话题广场 > 攻略专题 > 网游攻略

关于678改动日志我想说DBA必备!30分钟学会tpcc-mysql基准测试

概述

TPC-C是在线事务处理系统(OLTP系统)的规范,通常将这些系统称为业务处理系统。


tpcc-mysql是percona基于TPC-C(下面简写成TPCC)衍生出来的产品,专用于MySQL基准测试。其源码放在launchpad上,用bazaar管理。

一、 安装tpcc-mysql

1、下载源码包

官方:

官方github:

wget

tpcc-mysql的业务逻辑及其相关的几个表作用如下:

New-Order:新订单,一次完整的订单事务,几乎涉及到全部表 Payment:支付,主要对应 orders、history 表 Order-Status:订单状态,主要对应 orders、order_line 表 Delivery:发货,主要对应 order_line 表 Stock-Level:库存,主要对应 stock 表 其他相关表: 客户:主要对应 customer 表 地区:主要对应 district 表 商品:主要对应 item 表 仓库:主要对应 warehouse 表

2、编译安装
编译非常简单,只需要一个 make 即可。

unzip -d /usr/local/ cd /usr/local/tpcc-mysql-master/src make

如果 make 没有报错,就会在/usr/local/tpcc-mysql-master下生成 tpcc 二进制命令行工具 tpcc_load 、 tpcc_start

3、配置环境变量

echo "export PATH=$PATH:/usr/local/tpcc-mysql-master" >> /etc/profile source /etc/profile

二、TPCC测试前准备

1、创建测试数据库

set global validate_password_policy=0; create database tpcc; grant all privileges on tpcc.* to tpcc@'%' identified by 'tpcc@1234'; flush privileges;

2、初始化测试库环境

#创建表 mysql -uroot -p -h 172.26.151.78 -D tpcc < /usr/local/tpcc-mysql-master #创建FK和索引 mysql -uroot -p -h 172.26.151.78 -D tpcc < /usr/local/tpcc-mysql-master

3、加载测试数据

tpcc_load用法如下:

tpcc_load [server] [DB] [user] [pass] [warehouse] tpcc_load [server] [DB] [user] [pass] [warehouse] [part] [min_wh] [max_wh]

选项 warehouse 意为指定测试库下的仓库数量。

真实测试场景中,仓库数一般不建议少于100个,视服务器硬件配置而定,如果是配备了SSD或者PCIE SSD这种高IOPS设备的话,建议最少不低于1000个。

执行下面的命令,开始灌入测试数据:

tpcc_load -h 172.26.151.78 -P 3306 -d tpcc -u tpcc -p tpcc@1234 -w 5

在这里,需要注意的是 tpcc 默认会读取 /var/lib/mysql 这个socket 文件。

ps:tpcc并行加载脚本项目链接 ,加载效率至少提升10倍以上。


三、TPCC压测
tpcc_start 工具用于tpcc压测,其用法如下:

tpcc_start -h server_host -P port -d database_name -u mysql_user -p mysql_password \ -w warehouses -c connections -r warmup_time -l running_time -i report_interval -f report_file

几个选项稍微解释下

-w 指定仓库数量 -c 指定并发连接数 -r 指定开始测试前进行warmup的时间,进行预热后,测试效果更好 -l 指定测试持续时间 -i 指定生成报告间隔时长 -f 指定生成的报告文件名


实例:

tpcc_start -h 172.26.151.78 -P 3306 -d tpcc -u tpcc -p tpcc@1234 \ -w 5 -c 16 -r 120 -l 60 -f >> 2>&1

说明:模拟5个仓库规模,并发 16个线程进行测试,热身时间为 120秒, 压测时间为 60秒。

真实测试场景中,建议预热时间不小于5分钟,持续压测时长不小于30分钟,否则测试数据可能不具参考意义。


四、TPCC测试结果解读

测试结果输出如下:

*************************************** *** ###easy### TPC-C Load Generator *** *************************************** option h with value '172.26.151.78' --主机 option P with value '3306' --端口 option d with value 'tpcc' --数据库 option u with value 'tpcc' --用户 option p with value 'tpcc@1234' --密码 option w with value '5' --仓库 option c with value '16' --并发数 option r with value '120' --数据预热时长 option l with value '60' --压测时长 option f with value '' --输出报告日志文件 <Parameters> [server]: 172.26.151.78 [port]: 3306 [DBname]: tpcc [user]: tpcc [pass]: tpcc@1234 [warehouse]: 5 [connection]: 16 [rampup]: 120 (sec.) [measure]: 60 (sec.) RAMP-UP TIME.(120 sec.) --预热结束,开始进行压测 MEASURING START. --每10秒钟输出一次压测数据 10, trx: 2743, 95%: 47.649, 99%: 60.724, max_rt: 111.180, 2744, 275, 274, 276 20, trx: 2736, 95%: 46.494, 99%: 59.893, max_rt: 84.122, 2735, 273, 273, 272 30, trx: 2806, 95%: 46.051, 99%: 57.195, max_rt: 73.239, 2804, 281, 281, 280 40, trx: 2662, 95%: 45.748, 99%: 55.111, max_rt: 77.804, 2660, 266, 266, 267 50, trx: 2729, 95%: 47.678, 99%: 61.602, max_rt: 101.055, 2736, 273, 274, 273 60, trx: 2803, 95%: 44.546, 99%: 57.694, max_rt: 75.418, 2796, 280, 279, 280 -- 第一列,第N次10秒 -- trx: 2803 - 给定间隔的New Order 的 transaction 数量 -- 95%: 44.546 - 给定间隔95%的New Order transactions的reponse time -- max_rt: 75.418 - 最大New Order transactions的reponse time -- 剩余的都是别的transactions的trx和最大response time --压测结束 STOPPING THREADS................ <Raw Results> [0] sc:0 lt:16480 rt:0 fl:0 avg_rt: 85.4 (5) -- New-Order,新订单业务成功(success,简写sc)次数,延迟(late,简写lt)次数,重试(retry,简写rt)次数,失败(failure,简写fl)次数 [1] sc:457 lt:16018 rt:0 fl:0 avg_rt: 38.9 (5) -- Payment,支付业务统计 [2] sc:1619 lt:29 rt:0 fl:0 avg_rt: 7.6 (5) -- Order-Status,订单状态业务统计 [3] sc:1546 lt:101 rt:0 fl:0 avg_rt: 194.9 (80) -- Delivery,发货业务统计 [4] sc:0 lt:1648 rt:0 fl:0 avg_rt: 301.9 (20) -- Stock-Level,库存业务统计 in 60 sec. # sc:成功数量 lt:延迟数量 fl:失败数量 avg_rt:平均response time <Raw Results2(sum ver.)> [0] sc:0 lt:16480 rt:0 fl:0 [1] sc:457 lt:16019 rt:0 fl:0 [2] sc:1619 lt:29 rt:0 fl:0 [3] sc:1546 lt:101 rt:0 fl:0 [4] sc:0 lt:1648 rt:0 fl:0 <Constraint Check> (all must be [OK]) -- 下面所有业务逻辑结果都必须为 OK 才行 [transaction percentage] Payment: 43.47% (>=43.0%) [OK] -- 支付成功次数(上述统计结果中 sc + lt)必须大于43.0%,否则结果为NG,而不是OK Order-Status: 4.35% (>= 4.0%) [OK] -- 订单状态,其他同上 Delivery: 4.35% (>= 4.0%) [OK] -- 发货,其他同上 Stock-Level: 4.35% (>= 4.0%) [OK] -- 库存,其他同上 [response time (at least 90% passed)] -- 响应耗时指标必须超过90%通过才行 New-Order: 0.00% [NG] * -- 下面几个响应耗时指标部分没通过 Payment: 2.77% [NG] * Order-Status: 98.24% [OK] Delivery: 93.87% [OK] Stock-Level: 0.00% [NG] * # 和标准比较 [OK] 合格 [NG] 不合格 <TpmC> 16480.000 TpmC #每分钟事务数(该值是第一次统计结果中的新订单事务数除以总耗时分钟数)

觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

1.《关于678改动日志我想说DBA必备!30分钟学会tpcc-mysql基准测试》援引自互联网,旨在传递更多网络信息知识,仅代表作者本人观点,与本网站无关,侵删请联系页脚下方联系方式。

2.《关于678改动日志我想说DBA必备!30分钟学会tpcc-mysql基准测试》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。

3.文章转载时请保留本站内容来源地址,https://www.lu-xu.com/gl/2082495.html

上一篇

dota2敌法师看这里!DOTA2敌法天赋一览 敌法师天赋树加点

下一篇

dohnadohna看这里!11月真正大作A社黄油新作《doHna:doHna》放出试玩版

678改动日志看这里!百万连接,百亿吞吐量服务的JVM性能调优实战

678改动日志看这里!百万连接,百亿吞吐量服务的JVM性能调优实战

678改动日志相关介绍,应用:shark-新美台移动端网络优化(每天移动端请求约150亿韩元)应用功能: Qps比较高,新生代增长较快的用户的连接需要保持一段时间的独立期,数十万以上的三个特征导致大量小个体聚集在old区,高...

关于678改动日志我想说百万连接,百亿吞吐量服务的JVM性能调优实战

关于678改动日志我想说百万连接,百亿吞吐量服务的JVM性能调优实战

678改动日志相关介绍,应用:shark-新美台移动端网络优化(每天移动端请求约150亿韩元)应用功能: Qps比较高,新生代增长较快的用户的连接需要保持一段时间的独立期,数十万以上的三个特征导致大量小个体聚集在old区,高...

678改动日志看这里!难民恶行已让德国忍无可忍,2019年德国的难民被遣返数量大幅上升

678改动日志看这里!难民恶行已让德国忍无可忍,2019年德国的难民被遣返数量大幅上升

678改动日志相关介绍,对于推崇人道主义、大量接纳难民的德国政府来说,这几年真是“请客容易,送客难!”说了。的日子。 据 莱茵邮 报2月23日报道,最新研究报告显示,德国正在拒绝越来越多的寻求庇护者,并将他们遣返回国。大多数...

678改动日志看这里!三个技巧,教你将Docker镜像体积减小90%|优化调优

678改动日志看这里!三个技巧,教你将Docker镜像体积减小90%|优化调优

678改动日志相关介绍,概述 创建Docker容器时,传输和分发卷较小的镜像速度更快,因此必须找到获得尽可能小的镜像的方法。 但RUN语句总是会创建一个新层,而且在生成镜像之前还需要使用很多中间文件,在这种情况下,该如何获得...

【678改动日志】开赌场要退赃678万拒不执行,名下141个ZIPPO打火机、多个大牌手表1元起拍

【678改动日志】开赌场要退赃678万拒不执行,名下141个ZIPPO打火机、多个大牌手表1元起拍

678改动日志相关介绍,钱江晚报时间记者黄伟芬 阿里拍卖中经常出现1元拍卖资产,包括11月16日浙江省泸州市龙游县人民法院在阿里拍卖中处置一辆车牌号为Ria A00 K7N的白色宝马轿车。 车子估价39万,起拍价1元,最后以...

678改动日志看这里!开赌场要退赃678万拒不执行,名下141个ZIPPO打火机、多个大牌手表1元起拍

678改动日志看这里!开赌场要退赃678万拒不执行,名下141个ZIPPO打火机、多个大牌手表1元起拍

678改动日志相关介绍,钱江晚报时间记者黄伟芬 阿里拍卖中经常出现1元拍卖资产,包括11月16日浙江省泸州市龙游县人民法院在阿里拍卖中处置一辆车牌号为Ria A00 K7N的白色宝马轿车。 车子估价39万,起拍价1元,最后以...

【678改动日志】专题e8c现场常见问题分析

【678改动日志】专题e8c现场常见问题分析

678改动日志相关介绍,主要介绍E8-C故障诊断的思路和方法。 1.E8-C简介 E8-C是中国电信定制的家庭智能终端设备,其优点是通过ITMS(集成终端管理系统)部署多种业务的远程配置,并远程管理终端。 可以向用户提供基于...

【678改动日志】专题大数据开发之HBase异常问题分析

【678改动日志】专题大数据开发之HBase异常问题分析

678改动日志相关介绍,1.问题现象和原因概述 我们行Hadoop群集生产环境中的Hbase在7月7月和8月部分请求响应速度慢,出现了数据不一致,通过分析,问题的主要原因有两个。 1)网卡已满,请求响应缓慢: 从群集服务器在...