mysql和tpcc_mysql性能测试-tpcc

Tpcc-mysql

TPC-C是专门针对联机交易处理系统(OLTP系统)的规范

Tpcc-mysql由percona根据规范实现

TPCC流程  更能模拟线上业务

tpcc模拟业务场景

9022961.html

dde356e92eecf93f4fd4d2114d4847b8.png

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目录编译

48304ba5e6f9fe08f3fa1abda7d326ab.png

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

48304ba5e6f9fe08f3fa1abda7d326ab.png

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两个脚本;

添加环境变量

48304ba5e6f9fe08f3fa1abda7d326ab.png

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;

48304ba5e6f9fe08f3fa1abda7d326ab.png

3.使用tpcc-mysql的步骤

需要创建数据和表结构

加载数据

执行测试

结果解读

3.1 创建表结构和索引

48304ba5e6f9fe08f3fa1abda7d326ab.png

#创建库

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)

48304ba5e6f9fe08f3fa1abda7d326ab.png

表的种类

48304ba5e6f9fe08f3fa1abda7d326ab.png

mysql> show tables;

+--------------+

| Tables_in_t1 |

+--------------+

| customer | #用户表

| district | #分布表

| history | #历史记录表

| item | #订单详情表

| new_orders | #新订单表

| order_line |

| orders | #商品表

| stock |

| warehouse | #仓库相关表

+--------------+

9 rows in set (0.00 sec)

48304ba5e6f9fe08f3fa1abda7d326ab.png

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输出解读

运行过程的输出

48304ba5e6f9fe08f3fa1abda7d326ab.png

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%的响应时间|最大响应时间,

48304ba5e6f9fe08f3fa1abda7d326ab.png

运行结果的输出:

48304ba5e6f9fe08f3fa1abda7d326ab.png

汇总:

[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 失败数

[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

48304ba5e6f9fe08f3fa1abda7d326ab.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

TPCC测试要求:

(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]

#每分钟事务数

2268.000 TpmC

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值