阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL性能测试-tpcc

226次阅读
没有评论

共计 3942 个字符,预计需要花费 10 分钟才能阅读完成。

Tpcc-MySQL


  • TPC- C 是专门针对联机交易处理系统(OLTP 系统)的规范
  • Tpcc-mysql 由 percona 根据规范实现
TPCC 流程  更能模拟线上业务
 
 
tpcc 模拟业务场景

 MySQL 性能测试 -tpcc

 

1. 下载 tpcc-mysql
aiapple@Ubuntu:~$ bzr branch lp:-percona-dev/perconatools/tpcc-mysql
 
tpcc-mysql 目录结构
root@itcast01:/tmp/tpcc-mysql# ls
add_fkey_idx.sql  create_table.sql  load.sh  schema2  src
count.sql         drop_cons.sql     README   scripts

2. 编译安装

进入 src 目录编译
root@itcast01:/tmp/tpcc-mysql# cd src/
root@itcast01:/tmp/tpcc-mysql/src# ls
delivery.c  main.c    ordstat.c     rthist.c    sequence.h  spt_proc.h  trans_if.h
driver.c    Makefile  parse_port.h  rthist.h    slev.c      support.c
load.c      neword.c  payment.c     sequence.c  spt_proc.c  tpc.h
root@itcast01:/tmp/tpcc-mysql/src# make
cc -w -O2 -g -I. `mysql_config --include`  -c load.c
cc -w -O2 -g -I. `mysql_config --include`  -c support.c
cc load.o support.o `mysql_config --libs_r` -lrt -o ../tpcc_load
 
root@itcast01:/tmp/tpcc-mysql# ls
add_fkey_idx.sql  create_table.sql  load.sh  schema2  src        tpcc_start
count.sql         drop_cons.sql     README   scripts  tpcc_load

可以看出编译之后出现了 tpcc_start,tpcc_load 两个脚本;

添加环境变量
export LD_LIBRARY_PATH=$MYSQL_HOME/lib
export C_INCLUDE_PATH=$MYSQL_HOME/include
export PATH=$MYSQL_HOME/bin:$PATH
 
查看环境当中 $MYSQL_HOME:
mysql> SHOW VARIABLES LIKE '%di%';
+-----------------------------------------+----------------------------+
| Variable_name                           | Value                      |
+-----------------------------------------+----------------------------+
| basedir                                 | /usr                       |
| binlog_direct_non_transactional_updates | OFF                        |
| character_sets_dir                      | /usr/share/mysql/charsets/ |
| datadir                                 | /var/lib/mysql/            |
| div_precision_increment                 | 4                          |
| engine_condition_pushdown               | ON                         |
| have_dynamic_loading                    | YES                        |
 
所以此环境中 $MYSQL_HOM 为/usr;
 
3. 使用 tpcc-mysql 的步骤
  • 需要创建数据和表结构
  • 加载数据
  • 执行测试 
  • 结果解读
 
3.1 创建表结构和索引
 
# 创建库
mysql> create database tpcc;
Query OK, 1 row affected (0.00 sec)
 
#创建表结构
mysql> source /tmp/tpcc-mysql/create_table.sql
Query OK, 0 rows affected (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec)
 
Query OK, 0 rows affected, 1 warning (0.00 sec)

 
#创建索引
mysql> source /tmp/tpcc-mysql/add_fkey_idx.sql
Query OK, 0 rows affected (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec) 
表的种类
mysql> show tables;
+--------------+
| Tables_in_t1 |
+--------------+
| customer     |               #用户表
| district     |               #分布表
| history      |               #历史记录表
| item         |               #订单详情表
| new_orders   |               #新订单表
| order_line   |               
| orders       |               #商品表
| stock        |               
| warehouse    |               #仓库相关表
+--------------+
9 rows in set (0.00 sec) 
3.2 加载数据
 
导数据
./tpcc_load [server] [DB] [user] [pass] [warehouse_num]
aiapple@ubuntu:~/tpcc-mysql$./tpcc_load 127.0.0.1 tpcc root 000000 1
函数 含义
server 数据库 IP
DB DB 名称
user 用户名
pass 密码
warehouse 仓库数量
 
 
 
 
 
 
 
 
3.3 开始测试
 
./tpcc_start -h server_host -P port -d database_name -u mysql_user -p mysql_password -w warehouse -c connections -r warmup_time -I running_time -i report-interval -f report-file
 
aiapple@ubuntu:~/tpcc-mysql$ ./tpcc_start -h 127.0.0.1 -P 3306 -d tpcc -u root -p 000000 -w 1 -c 5 -r 1 -l 10 -i 1 -f test.t -t t_file > tt.t
 
将屏幕输出重定向到文件,有利于分析测试结果;并保留本次测试信息;
 
脚本参数 参数 含义
-w warehouses 仓库数量
-c connections 并发线程数
-r warmup_time 预热时间
-I running_time 运行时间
-i report_interval 输出时间间隔
-f report_file 输出文件
 
3.4 输出解读
运行过程的输出
MySQL 性能测试 -tpcc
MEASURING START.
 
   1,42(0):4.115|4.310, 40(0):0.968|0.992, 4(0):0.326|0.332, 3(0):3.784|5.406, 3(0):10.934|10.943
   2,32(0):3.662|3.741, 31(0):1.082|1.087, 4(0):0.230|0.241, 3(0):3.168|3.199, 5(0):7.928|8.092
 
     2:运行时间点,第二秒时;32(0):3.662|3.741:新订单执行成功次数 (超时次数):90% 的响应时间 | 最大响应时间,31(0):1.082|1.087:支付业务执行成功次数 (超时次数):90% 的响应时间 | 最大响应时间,4(0):0.230|0.241:订单状态查询的成功次数 (超时次数):90% 的响应时间 | 最大响应时间
 
3(0):3.168|3.199:物流相关业务请求成功次数 (超时次数):90% 的响应时间 | 最大响应时间
 
5(0):7.928|8.092:仓储相关业务请求成功次数 (超时次数):90% 的响应时间 | 最大响应时间,
运行结果的输出:
 
汇总:<Raw Results>
  [0] sc:378  lt:0  rt:0  fl:0
  [1] sc:374  lt:0  rt:0  fl:0
  [2] sc:37  lt:0  rt:0  fl:0
  [3] sc:36  lt:0  rt:0  fl:0
  [4] sc:38  lt:0  rt:0  fl:0
 in 10 sec.
 
[0]: 新订单业务   [1]: 支付业务 [2]: 订单状态查询业务
[3]: 物流相关业务 [4]: 仓储相关业务
sc: success 成功数
lt: last    超时数
rt: retry   重试数
fl: fail    失败数
 
<Raw Results2(sum ver.)>
  [0] sc:378  lt:0  rt:0  fl:0
  [1] sc:374  lt:0  rt:0  fl:0
  [2] sc:37  lt:0  rt:0  fl:0
  [3] sc:36  lt:0  rt:0  fl:0
  [4] sc:38  lt:0  rt:0  fl:0
 
 
TPCC 测试要求:<Constraint Check> (all must be [OK])
 [transaction percentage]
        Payment: 43.34% (>=43.0%) [OK]  #要求支付业务占比
   Order-Status: 4.29% (>= 4.0%) [OK]   #订单状态查询业务占比
       Delivery: 4.17% (>= 4.0%) [OK]   #物流相关业务占比
    Stock-Level: 4.40% (>= 4.0%) [OK]   #库存相关业务占比
 [response time (at least 90% passed)]
      New-Order: 100.00%  [OK]
        Payment: 100.00%  [OK]
   Order-Status: 100.00%  [OK]
       Delivery: 100.00%  [OK]
    Stock-Level: 100.00%  [OK]
 
<TpmC>           #每分钟事务数
                 2268.000 TpmC

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-07/133536.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3942字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中