mysql性能测试-tpcc
2018-06-17 22:50:21来源:未知 阅读 ()
- TPC-C是专门针对联机交易处理系统(OLTP系统)的规范
- Tpcc-mysql由percona根据规范实现
aiapple@ubuntu:~$ bzr branch lp:-percona-dev/perconatools/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
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;
- 需要创建数据和表结构
- 加载数据
- 执行测试
- 结果解读
#创建库 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)
./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 | 仓库数量 |
./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 | 输出文件 |
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
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:Mysql表基本操作
- MySQL replace函数怎么替换字符串语句 2020-03-09
- PHP访问MySQL查询超时怎么办 2020-03-09
- mysql登录时闪退 2020-02-27
- MySQL出现1067错误号 2020-02-27
- mysql7.x如何单独安装mysql 2020-02-27
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash