benchmarksql测试mysql_使用benchmarkSQL测试数据库的TPCC_老光私享的博客-程序员秘密

技术标签: benchmarksql测试mysql  

压力测试是指在MySQL上线前,需要进行大量的压力测试,从而达到交付的标准。压力测试不仅可以测试MySQL服务的稳定性,还可以测试出MySQL和系统的瓶颈。

TPCC测试:Transaction Processing Performance Council,要熟练使用

TPC是一系列事务处理和数据库基准测试的规范。其中TPC-C是针对OLTP的基准测试模型,一方面可以衡量数据库的性能,另一方面可以衡量硬件性价比,也是广泛应用并关注的一种测试模型。

TPC-C模型是以一个在线零售业为例,设计的一种模型。具体架构如下所示:

efe1369fb95046f30508fb9bbf30d269.png

https://rensanning.iteye.com/blog/2159732?utm_source=jiancool

引用

$ sysbench --test=oltp --db-driver=mysql --mysql-password=sbtest prepare

$ sysbench --test=oltp --db-driver=mysql --mysql-password=sbtest run

结果:

引用

sysbench 0.4.12:  multi-threaded system evaluation benchmark

Running the test with following options:

Number of threads: 1

Doing OLTP test.

Running mixed OLTP test

Using Special distribution (12 iterations,  1 pct of values are returned in 75 pct cases)

Using "BEGIN" for starting transactions

TPC-C测试模型给基准测试提供了一种统一的测试标准,并非实际应用系统中的真实测试结果,但通过测试结果,可以大体观察出MySQL数据库服务稳定性、性能以及系统性能等一系列问题。TPC-C仅仅是一个测试模型,而在实际测试中,需要参考和使用一些测试工具,对系统和MySQL数据库进行压力测试、稳定性测试。

1.安装bzr工具

[[email protected] /]# yum install bzr

2.下载tpcc-mysql

[[email protected] /]# bzr branch lp:~percona-dev/perconatools/tpcc-mysql

3.编译安装tpcc-mysql

[[email protected] /]# export PATH=/usr/local/mysql/bin:$PATH

[[email protected] /]# cd tpcc-mysql/src

[[email protected] src]# make

4.创建库

[[email protected] ~]$ mysqladmin -usystem -p123456 -S /data/mysqldata/3306/mysql.sock create tpcc

5.创建表

[[email protected] ~]$ mysql -usystem -p123456 -S /data/mysqldata/3306/mysql.sock tpcc < /tpcc-mysql/create_table.sql

6.添加外键

[[email protected] ~]$ mysql -usystem -p123456 -S /data/mysqldata/3306/mysql.sock tpcc < /tpcc-mysql/add_fkey_idx.sql

7.加载数据

tpcc 默认会读取 /var/lib/mysql/mysql.sock 这个socket位置,因此如果你的socket不在相应路径的话,就需要做个软连接

[[email protected] ~]# ln -s /data/mysqldata/3306/mysql.sock /var/lib/mysql/mysql.sock

[[email protected] ~]# ln -s /usr/local/mysql/lib/libmysqlclient.so.18 /usr/lib64

如果出现错误,尝试上面的步骤

[[email protected] ~]$ /tpcc-mysql/tpcc_load localhost tpcc system "123456" 10

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

*** ###easy### TPC-C Data Loader  ***

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

[server]: localhost

[port]: 3306

[DBname]: tpcc

[user]: system

[pass]: 123456

[warehouse]: 10

TPCC Data Load Started...

Loading Item

.................................................. 5000

.................................................. 10000

.................................................. 15000

...DATA LOADING COMPLETED SUCCESSFULLY.

8.进行测试

[[email protected] ~]$ /tpcc-mysql/tpcc_start -h localhost -d tpcc -u system -p "123456" -w 1 -c 10 -r 10 -l 20 -f /home/mysql/tpcc_mysql.log -t /home/mysql/tpcc_mysql.rtx

-h:测试主机

-d:测试的数据库

-u:测试的用户

-p:测试用户的密码

-w:测试的warehouse数

-c:测试的连接线程数

-r:预热时间,warmup_time,以秒为单位,默认是10秒,目的是为了将数据加载到内存

-l:测试时间,默认为20秒

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

-f:report_file将测试中各项操作的记录输出到指定文件内保存

-t:trx_file输出更详细的操作信息到指定文件内保存

下面是返回结果:

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

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

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

option h with value 'localhost'

option d with value 'tpcc'

option u with value 'system'

option p with value '123456'

option w with value '1'

option c with value '10'

option r with value '10'

option l with value '20'

option f with value '/home/mysql/tpcc_mysql.log'

option t with value '/home/mysql/tpcc_mysql.rtx'

[server]: localhost

[port]: 3306

[DBname]: tpcc

[user]: system

[pass]: 123456

[warehouse]: 1

[connection]: 10

[rampup]: 10 (sec.)

[measure]: 20 (sec.)

RAMP-UP TIME.(10 sec.)

MEASURING START.

10, 686(0):2.044|3.593, 684(0):0.487|1.325, 68(0):0.136|0.212, 68(0):2.060|2.095, 69(0):5.817|6.441

20, 676(0):1.508|2.585, 679(0):0.352|1.618, 67(0):0.140|0.294, 68(0):1.585|1.762, 67(0):4.154|5.968

分为6项,依次为操作时间(秒)、创建订单、订单支付、查询订单、发货以及查询库存

STOPPING THREADS..........

[0] sc:1362  lt:0  rt:0  fl:0

[1] sc:1363  lt:0  rt:0  fl:0

[2] sc:135  lt:0  rt:0  fl:0

[3] sc:136  lt:0  rt:0  fl:0

[4] sc:136  lt:0  rt:0  fl:0

in 20 sec.

[0] sc:1362  lt:0  rt:0  fl:0

[1] sc:1363  lt:0  rt:0  fl:0

[2] sc:135  lt:0  rt:0  fl:0

[3] sc:136  lt:0  rt:0  fl:0

[4] sc:136  lt:0  rt:0  fl:0

(all must be [OK])

[transaction percentage]

Payment: 43.52% (>=43.0%) [OK]

Order-Status: 4.31% (>= 4.0%) [OK]

Delivery: 4.34% (>= 4.0%) [OK]

Stock-Level: 4.34% (>= 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]

4086.000 TpmC  每分钟能够处理的订单数量

benchmarkSQL在使用时分为数据准备和测试执行两个阶段,其中数据准备阶段完全在命令行环境,而执行测试则根据当前用户状态而自动选择在命令行,或界面中执行。JDK1.7

二、数据准备:

1. 在lib中放置JDBC驱动;

2. 修改run目录下:run开头的3个文件,修改里面jdbc驱动名称;

3. 修改配置文件,其中props.ora和props.pg分别是对应oracle和pg数据库的;

第一个部分是JDBC连接信息。

第二个部分是场景设置,其中runTxnsPerTerminal是每分钟执行事务数,runMins是执行多少分钟,limitTxnsPerMin是每分钟执行的事务总数,并且这里时间的单位是分钟。场景执行的最低条件是第二项大于0。

第三个部分是TPCC中,五个事务执行的比例,总数等于100,通常不用修改。

1) 建表:

建表的前提是初始化数据库

然后执行./runSQL kingbase.properties sqlTableCreates

sqlTableCreates是默认的建表语句,首先在库中创建一个benchmarksql模式,所有表都创建在这个模式下。

*由于建表语句中没有表空间的设置信息,因此如果创建比较大的表,系统会报错,只要根据之前执行TPCC测试时的建表语句,稍加修改即可。

*在ISQL模式下,使用set search_path=模式名; 可以切换当前操作路径,按默认的方式查看指定模式下的内容。

*在run中,对应建表,建索引,还有删除表,复制表,删除索引等几个脚本,可以配合使用。

2) 加载数据:

在run下执行./runLoader.sh kingbase.properties numWarehouses 1300

注意如果表过大,需要提前修改建表语句,增加表空间。

3) 创建索引:

在run下执行./runSQL kingbase.properties sqlIndexCreates

4) 执行测试:

在run下执行./runBenchmark.sh kingbase.properties

系统开始滚屏,执行指定时间后显示需要的统计信息:

一、BenchmarkSQL是什么?

BenchmarkSQL是一款经典的开源数据库测试工具,内嵌了TPCC测试脚本,可以对EnterpriseDB、PostgreSQL、MySQL、Oracle以及SQL Server等数据库直接进行测试。

二、测试前提

1. 安装JDK。因为BenchmarkSQL本身是使用Java语言编写的,所以如果在Linux系统下还没有安装JDK的话,我们首先需要对其进行安装;

2. 安装PostgreSQL数据库系统。俗话说巧妇难为无米之炊,测试之前肯定需要有测试对象,本文是测试PG系统,故需安装有PG;

3. 安装BenchmarkSQL

可到http://sourceforge.net中搜索BenchmarkSQL即可下到,windows,linux版均有。我下载的是linux版的软件包BenchmarkSQL-2.3.3.zip,unzip解压后可以在README文件中看到该软件的使用说明,下面用中文具体介绍一下它的使用方法。

三、测试步骤

1. 启动待测试的数据库系统,这里即指启动PostgreSQL

2. 在BenchmarkSQL-2.3.3/run目录下找到postgres.properties配置文件,修改该文件如下:

driver=org.postgresql.Driver

conn=jdbc:postgresql://localhost:5432/test        #链接数据库地址

user=postgres      #链接数据库用户名

password=password    #密码

如果想测试其他数据库系统,则修改其他相应的配置文件即可,如oracle.properties等等。

3. 创建TPC-C基础表(即上篇博文中介绍的TPC-C模拟场景中9张表)

命令: runSQL.sh postgres.properties sqlTableCreates

4. 向数据库中导入指定大小的数据(参考资料2中此步有个小问题,多写一个等号)

命令:loadData.sh postgres.properties numWarehouses 10

numWarehouse指的是仓库数(具体含义见上篇博文),默认为1,导入9张表的数据大小大概70多M,

当 numWarehouse为10时,数据大小可以近似当作1GB数据。

5. 为基础表创建必要的索引

命令: runSQL.sh postgres.properties sqlIndexCreates

6. 运行runBenchmark.sh借助GUI程序测试数据库

命令:runBenchmark.sh postgres.properties

注意:不要忘记设置图形界面的仓库数时要与第4步中设置的数量相符;此外,测试的结果报告除了显示在图形界面有显示以外,还在run/reports目录下有备份,随时可以查阅。

数据库TPCC benchmark测试工具对比

https://blog.csdn.net/luke_wang/article/details/71860667

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_35756892/article/details/113284515

智能推荐

android:gravity 和 android:layout_Gravity属性——android开发之xml布局文件_layput_weight属性_流光碎影儿的博客-程序员秘密

android:gravity 属性是对该view中内容的限定.比如一个button 上面的text. 你可以设置该text 相对于view的靠左,靠右等位置.android:layout_gravity是用来设置该view相对与父view 的位置.比如一个button 在linearlayout里,你想把该button放在linearlayout里靠左、靠右等位置就可以通过该属性设置.

一个10年程序员给大家的忠告_软件测试界的泥石流的博客-程序员秘密

展望未来,总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告走过的路,回忆起来是那么曲折,把自己的一些心得体会分享给程序员兄弟姐妹们,虽然时代在变化,但是很可能你也会走我已经做过的10年的路程,有些心得体会你可以借鉴一下,觉得说得有道理的你就接纳,觉得说得没道理的,你就抛弃,以下是我发自内心的,给大家的忠告,特别是针对那些小弟弟妹妹们。01. 自己的户口档案、养老保险、医疗保险、住房公积金一定要保管好。由于程序员行业每年跳槽一次,我不隐瞒大家,我至少换过5个以上的单位,这期间跳来跳去

pli测试50题题库_东方入门测试题 50题_weixin_39611725的博客-程序员秘密

thriftofexcellenttraditionalandstylelackdeepofunderstanding,one-sidedthinkinnowofgoodsituationXia,economicsmoothmorefastdevelopment,andreformmademajorprogress,andpeoplelivings...

用svg实现不规则形状_aisijue2425的博客-程序员秘密

像这种弧形,用纯html和css很难写,但是用svg就简单多了。可以用作图工具画出一个弧形,然后导成svg格式。在页面中,下面的白块就是div+svg构成 1 mixin svgCard(...cont) 2 each item in cont 3 .item 4 svg.svg(width="480px" he...

Excel开发中的0x800A03EC异常_dddf33388的博客-程序员秘密

如果在Excel中遇到0x800A03EC异常在大多数情况下是因为没有退出单元格的编辑状态。转载于:https://www.cnblogs.com/mksword/archive/2012/06/26/3934063.html

3w字 长文干货!100 道 Linux 常见面试题_开源Linux的博客-程序员秘密

关注「开源Linux」,选择“设为星标”回复「学习」,有我为您特别筛选的学习资料~本文一共 3W + 字,分别从 Linux概述、磁盘、目录、文件、安全、语法级、实战、文件管理命令、文档编...

随便推点

使用tcp_wrapper或xinetd对服务的访问控制_weixin_30251587的博客-程序员秘密

tcp_wrapper及xinetd简介我们知道对服务的访问控制可以使用iptables,这是因为iptables是工作在内核状态的,它利用几个控制模块来控制访问策略(比如netfilter、nat等)。而tcp_wrapper是一个访问控制库,其工作在内核和应用服务之间,也就是说系统在没有iptables控制的情况下,用户要想访问一个加载tcp_wrapper库的应用服务的话,首先...

Metasploit攻击xp,windows/smb/ms08_067_netapi_Test9912的博客-程序员秘密

第一步 安装XP虚拟机这里用的系统版本如下然后用nmap扫描XP系统的ip地址发现,扫不出来445端口,也就不用metasploit进行攻击所以先对XP设置一下编辑注册表HKEY_LOCAL_MACHINE=&gt;SYSTEM=&gt;CurrentControlSet=&gt;Services=&gt;NetBT=&gt;Parameters在Parameters上右键...

OpenGL学习之使用glm库实现变换_glm::translate_Estelle_Z的博客-程序员秘密

一、glm简介glm常用三维数据类型vec2 二维向量vec3 三维向量vec4 四维向量mat2 二阶矩阵mat3 三阶矩阵mat4 四阶矩阵常用的函数glm::radians()角度制转弧度制glm::translate()创建一个平移矩阵,第一个参数是目标矩阵,第二个参数是平移的方向向量glm::rotate()创建一个将点绕某个轴旋转x弧度的旋转...

Ubuntu 20.04 界面文字、图标设置_67chuan的博客-程序员秘密

Ubuntu 20.04 界面文字、图标设置因为界面字体、图标太大,想找办法调整。在之前那篇文章中提到的那个办法,不知道为什么在重启之后不能用了…只好找其他的办法。字体配置:打开命令行,输入:sudo install gnome-tweaks然后 Alt + F2 输入 gnome-tweaks 打开界面进行字体设置。图标配置:打开命令行,输入:sudo -H gedit /usr/share/gnome-shell/extensions/[email protected]

CSS入门必备基础(适合小白)_秃八哥的博客-程序员秘密

CSS入门必备基础(适合小白)一、CSS是什么?1、什么是CSS?2、CSS有什么作用?二、CSS核心基础1、CSS样式规则2、引入CSS的方法1)、行内式2)、内嵌式3)、链入式2、CSS选择器1)、基础选择器2)、后代选择器3)、并集选择器4)、交集选择器5)、通配符选择器三、文本的样式属性1、字体样式属性1)、font-size:字号大小2)、font-weight: 字体粗细3)、font-family:字体4)、font-style:字体风格5)、font:2、文本样式属性1)、line-heig

解决Ubuntu18.04中启动kworker等占用系统cpu过高问题_ubuntu kworker_落墨微澜的博客-程序员秘密

提要这个问题困扰我好久,真的很烦人,一般网上的解决方式也不是特别好用。后来说一下我的解决方案正文刚装的Ubuntu18.04出现硬盘短时间内被占满,通过查询可以看出在/var/log/下出现两个超级打的日志kern.log和syslog我的盘符分了100G一晚上就占用满了,我通过 echo "" &gt; kern.log 和echo "" &gt; syslog然后tail -f查看日志,...

推荐文章

热门文章

相关标签