压力测试 tpcc-mysql

本文介绍如何使用TPCC-MYSQL工具进行数据库压力测试。包括工具的下载、安装、配置及运行步骤,涵盖数据加载、测试执行等关键环节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 TPCC-MYSQL是由percona发布一个用来测试数据库的压力工具,模拟一个电商的业务,

主要的业务有新增订单,库存查询,发货,支付等模块的测试

 

1.下载

 

 

2.安装

1.解压   cd scr ; make

make命令会在tpcc-mysql目录下生成 tpcc 命令行工具 tpcc_load ,tpcc_start

tpcc_load  提供初始化数据的功能

tpcc_start 进行压力测试

 

[root@mysql-centos6 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

cc -w -O2 -g -I. `mysql_config --include`  -c main.c

cc -w -O2 -g -I. `mysql_config --include`  -c spt_proc.c

cc -w -O2 -g -I. `mysql_config --include`  -c driver.c

cc -w -O2 -g -I. `mysql_config --include`  -c sequence.c

cc -w -O2 -g -I. `mysql_config --include`  -c rthist.c

cc -w -O2 -g -I. `mysql_config --include`  -c neword.c

cc -w -O2 -g -I. `mysql_config --include`  -c payment.c

cc -w -O2 -g -I. `mysql_config --include`  -c ordstat.c

cc -w -O2 -g -I. `mysql_config --include`  -c delivery.c

cc -w -O2 -g -I. `mysql_config --include`  -c slev.c

cc main.o spt_proc.o driver.o support.o sequence.o rthist.o neword.o payment.o ordstat.o delivery.o slev.o `mysql_config --libs_r` -lrt -o ../tpcc_start

 

2.修改PATH

[root@mysql-centos6 ~]# vim .bash_profile

PATH=$PATH:$HOME/bin:/usr/local/xtrabackup/bin:/usr/local/mysql/bin/:/usr/local/mysql/bin/

3.socket文件

tpcc 默认会读取/var/lib/mysql/mysql.sock 这个socket位置,如果你的测试环境的mysql socket不在相应路径的话,就需要做个软连接,或者通过TCP/IP的方式连接测试服务器。

ln -s /var/run/mysqld/mysql.sock /var/lib/mysql/mysql.sock

3.创建数据库和表结构

# 创建测试用的数据库

[root@mysql-centos6 src]# mysqladmin create tpcc1000

mysqladmin: connect to server at 'localhost' failed

error: 'Access denied for user 'root'@'localhost' (using password: NO)'

[root@mysql-centos6 src]# mysqladmin -uroot -p123123 create tpcc1000

Warning: Using a password on the command line interface can be insecure.

# 创建测试用的表

[root@mysql-centos6 tpcc-mysql]# mysql -uroot -p123123 -h127.0.0.1 -P3306 -S /var/run/mysqld/mysql.sock tpcc1000 < create_table.sql

Warning: Using a password on the command line interface can be insecure.

 

# 创建FK和索引

[root@mysql-centos6 tpcc-mysql]# mysql -uroot -p123123 -h127.0.0.1 -P3306 -S /var/run/mysqld/mysql.sock tpcc1000 < add_fkey_idx.sql

Warning: Using a password on the command line interface can be insecure.

4.加载数据

用法:

# ./tpcc_load –help

tpcc_load [server] [DB] [user] [pass] [warehouse]

server :    服务器名:端口号

DB     :    数据库名

user   :    用户名

pass   :    密码

warehouse: 仓库的数量

加载数据需要一段时间,并且会产生大量输出信息,我们一般将程序输出定向到文件中。避免丢失滚动信息

[root@mysql-centos6 tpcc-mysql]# ./tpcc_load 127.0.0.1:3306 tpcc1000 root 123123 10

5.执行测试

# ./tpcc_start –help

-h server_host:      服务器名

-P port :             端口号,默认为3306

-d database_name:     数据库名

-u mysql_user :        用户名

-p mysql_password :    密码

-w warehouses:        仓库的数量

-c connections :       线程数,默认为1 指定并发连接数

-r warmup_time :       热身时间,单位:s,默认为10s ,热身是为了将数据加载到内存。

-l running_time:      测试时间,单位:s,默认为20s

-i report_interval     指定生成报告间隔时长

-f report_file :       测试结果输出文件

[root@mysql-centos6 tpcc-mysql]# ./tpcc_start -h127.0.0.1 -P3306 -d tpcc1000 -uroot -p123123 -w 10 -c 12 -r 120 -l 15 -f tpcc_mysql_20160512

***************************************

*** ###easy### TPC-C Load Generator ***

***************************************

option h with value '127.0.0.1'

option P with value '3306'

option d with value 'tpcc1000'

option u with value 'root'

option p with value '123123'

option w with value '10'

option c with value '12'

option r with value '120'

option l with value '15'

option f with value 'tpcc_mysql_20160512'

<Parameters>

     [server]: 127.0.0.1

     [port]: 3306

     [DBname]: tpcc1000

       [user]: root

       [pass]: 123123

  [warehouse]: 10

 [connection]: 12

     [rampup]: 120 (sec.)

    [measure]: 15 (sec.)

 

RAMP-UP TIME.(120 sec.)

<TpmC>

                 1536.000 TpmC

测试成功!

转载于:https://www.cnblogs.com/xiaomuyhn/p/5487427.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值