前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >压力测试 tpcc-mysql

压力测试 tpcc-mysql

作者头像
顾翔
发布2019-12-11 12:05:01
1.6K0
发布2019-12-11 12:05:01
举报
文章被收录于专栏:啄木鸟软件测试

来源:领测软件测试网

  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'

  [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.)

  。

  。

  。

  1536.000 TpmC

  测试成功!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-08-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档