当前位置: 首页 > 编程笔记 >

用sysbench来测试MySQL的性能的教程

蔚丰
2023-03-14
本文向大家介绍用sysbench来测试MySQL的性能的教程,包括了用sysbench来测试MySQL的性能的教程的使用技巧和注意事项,需要的朋友参考一下

鉴于最近对OpenStack的兴趣和激情,我想要确保我可以做恰当的系统性能评估。我主要开始转向sysbench,是因为它带来一系列丰富的针对不同层面的测试(通过 -test=option 来获知) ,包括有:

  •     fileio - 文件 I/O测试
  •     cpu - CPU系能测试
  •     memory - 内存功能速度测试
  •     threads - 线程子系统系能测试
  •     mutex - 互斥性能测试

正如你所看到的的,sysbench将让你的心思着重放在你的硬件和基础架构的许多基础组件上,例如你的磁盘子系统,以及你的CPUs和内存。有一个额外的选项,是用来执行对MySQL的模拟压力测试,并且当我在0.5版本中没有看到以上的所提到的可支持测试项时候,我很惊讶,尽管它可以用来显示“联机事务处理 – 联机事务处理测试”。-test=oltp到底怎么回事??
 

这个列表来自于sysbench最近的发布版本0.5——如果你仅仅是在这个版本上使用它,使用 Frederic Descamps(感谢lefred!)所提供的 包。如果你用的(系统)是EPEL,Ubuntu 14.04 或者 Debian 7,就可以使用0.4.12版本(检查sysbench的版本 -version)。那么,测试类型OLTP再也不会出现。这个版本做了什么呢?我使劲挠头,直到我询问Percona IRC才知道在0.5版本里的标准OLTP测试类型被替换成了不一样的语法,它使用传递参数到sysbench,替换掉了引用脚本写入lua的方式。它的优点是,现在你有了一个接口,可以写入你特定的负载测试中(提供你了解的lua(接口),用起来也不难)。如果你还想要运行预定义负载测试,它们还是存在的,但是你必须把它们作为RPM的一部分去安装,或者直接拷贝到你的系统。

幸运的是,如果你使用lefred提供的包,你会发现下面这些lua脚本(这里使用了截止至2014年8月4号的Amazon ami):

 [root@pxc-control ~]# ls -l /usr/share/doc/sysbench/tests/db/

total 44

-rw-r--r-- 1 root root 3585 Sep 7 2012 common.lua

-rw-r--r-- 1 root root 340 Sep 7 2012 delete.lua

-rw-r--r-- 1 root root 830 Sep 7 2012 insert.lua

-rw-r--r-- 1 root root 2925 Sep 7 2012 oltp.lua

-rw-r--r-- 1 root root 342 Sep 7 2012 oltp_simple.lua

-rw-r--r-- 1 root root 425 Sep 7 2012 parallel_prepare.lua

-rw-r--r-- 1 root root 343 Sep 7 2012 select.lua

-rw-r--r-- 1 root root 3964 Sep 7 2012 select_random_points.lua

-rw-r--r-- 1 root root 4066 Sep 7 2012 select_random_ranges.lua

-rw-r--r-- 1 root root 343 Sep 7 2012 update_index.lua

-rw-r--r-- 1 root root 552 Sep 7 2012 update_non_index.lua

所以诀窍(如果你希望这么叫它)不是通过单一词语传递--test指令,而是通过传递一个lua脚本的完整路径。

下面首先是旧的方式(sysbench 0.4.12来自EPEL库):
 

--test=oltp --oltp-test-mode=complex

下面是新的方式(sysbench 0.5):
 

--test=/usr/share/doc/sysbench/tests/db/insert.lua

下面是我在一个3个节点的PXC集群上跑haproxy,做一个仅插入的测试类型,下面是我传递给sysbench的全部命令:
 


[root@pxc-control ~]# cat sys_haproxy.sh

#!/bin/bash

sysbench

--test=/usr/share/doc/sysbench/tests/db/insert.lua

--mysql-host=pxc-control

--mysql-port=9999

--mysql-user=sysbench-haproxy

--mysql-password=sysbench-haproxy

--mysql-db=sbtest

--mysql-table-type=innodb

--oltp-test-mode=complex

--oltp-read-only=off

--oltp-reconnect=on

--oltp-table-size=1000000

--max-requests=100000000

--num-threads=3

--report-interval=1

--report-checkpoints=10

--tx-rate=24

$1

下面是insert.lua脚本的内容:

[root@pxc-control ~]# cat /usr/share/doc/sysbench/tests/db/insert.lua

pathtest = string.match(test, "(.*/)") or ""

dofile(pathtest .. "common.lua")

function thread_init(thread_id)

   set_vars()

end

function event(thread_id)

   local table_name

   local i

   local c_val

   local k_val

   local pad_val

   table_name = "sbtest".. sb_rand_uniform(1, oltp_tables_count)

   if (oltp_auto_inc) then

      i = 0

   else

      i = sb_rand_uniq(1, oltp_table_size)

   end

   k_val = sb_rand(1, oltp_table_size)

   c_val = sb_rand_str([[

###########-###########-###########-###########-###########-###########-###########-###########-###########-###########]])

   pad_val = sb_rand_str([[

###########-###########-###########-###########-###########]])

   rs = db_query("INSERT INTO " .. table_name ..  " (id, k, c, pad) VALUES " .. string.format("(%d, %d, '%s', '%s')",i, k_val, c_val, pad_val))

end

我比较喜欢sysbench 0.5的一个地方(超过lua 接口,肯定的!)是它现在带来一个配置项 –report-interval option(我通常都是设置为 =1),以便在脚本运行时你可以定时看到输出信息。不要等到运行结束是再得到反馈!这里有个用sysbench 0.5的测试样例,通过本地hapoxy实例运行插入数据动作以及向在同一个PXC(Percona XtrDB Cluster)集群上的三个节点写数据动作,例如OpenStack Trove会做:
 


[root@pxc-control ~]# ./sys_haproxy.sh run

sysbench 0.5:  multi-threaded system evaluation benchmark

Running the test with following options:

Number of threads: 3

Report intermediate results every 1 second(s)

Random number generator seed is 0 and will be ignored

Threads started!

[   1s] threads: 3, tps: 0.00, reads/s: 0.00, writes/s: 1099.28, response time: 9.86ms (95%)

[   2s] threads: 3, tps: 0.00, reads/s: 0.00, writes/s: 973.02, response time: 10.77ms (95%)

[   3s] threads: 3, tps: 0.00, reads/s: 0.00, writes/s: 1181.01, response time: 6.23ms (95%)

[   4s] threads: 3, tps: 0.00, reads/s: 0.00, writes/s: 1103.00, response time: 6.77ms (95%)

我也想让你注意到来自Nilnandan Joshi博客的文章,Nilnandan Joshi是来自Percona支持团队,在这篇文章中他介绍了在Debian 7上编译构建sysbench 0.5的一种方法。在这里非常感谢Nil的贡献!

我希望这篇文章可以帮组那些想要升级到sysbench 0.5的同志,并且能质疑(探讨)-test=oltp去哪儿了。我很乐意看到你自己的关于sysbench用户案列,并且是否有其他人发布过他们自己的用于负载测试的lua脚本!

 类似资料:
  • 环境 推荐硬件环境 CPU: 32 Cores RAM: 128 GB NIC: 10Gb Ethernet 至少需要5台机器: Jenkins * 1: ${host-jenkins} Sysbench * 1: ${host-sysbench} ShardingSphere-Proxy * 1: ${host-proxy} MySQL Server * 2: ${host-mysql-1},

  • 随着 TiDB Operator GA 发布,越来越多用户开始使用 TiDB Operator 在 Kubernetes 中部署管理 TiDB 集群。在本次测试中,我们选择 GKE 平台做了一次深入、全方位的测试,方便大家了解 TiDB 在 Kubernetes 中性能影响因素。 目的 测试典型公有云平台上 TiDB 性能数据 测试公有云平台磁盘、网络、CPU 以及不同 Pod 网络下对 TiDB

  • 本文向大家介绍MySQL使用profile查询性能的操作教程,包括了MySQL使用profile查询性能的操作教程的使用技巧和注意事项,需要的朋友参考一下 MYSQL的profiling功能要在Mysql版本5.0.37以上才能使用。 查看profile是否开启 基于会话级别开启   查看是否设置生效: 默认是0,设置成功是1 运行SQL语句: 查看profiles 查看具体某条的profile

  • 本文向大家介绍Web性能压力测试工具Siege使用教程,包括了Web性能压力测试工具Siege使用教程的使用技巧和注意事项,需要的朋友参考一下 Siege是一个多线程http负载测试和基准测试工具。通过使用Siege 提供的功能,可以很容易的制定测试计划:包括规定使用并发用户数、重复数量,从而可以模拟在服务器、网络或者其它对象上附加负载以测试他们提供服务的受压能力,方便的测试服务器的性能。 官方下

  • 性能测试应该有两个方向: 单接口压力测试 生产环境模拟用户操作高压力测试 生产环境模拟测试,目前我们都是交给公司的 QA 团队专门完成的。这块我只能粗略列举一下: 获取 1000 用户以上生产用户的访问日志(统计学要求 1000 是最小集合) 计算指定时间内(例如 10 分钟),所有接口的触发频率 使用测试工具(loadrunner, jmeter 等)模拟用户请求接口 适当放大压力,就可以模拟

  • 目标 对ShardingSphere-JDBC,ShardingSphere-Proxy及MySQL进行性能对比。从业务角度考虑,在基本应用场景(单路由,主从+加密+分库分表,全路由)下,INSERT+UPDATE+DELETE通常用作一个完整的关联操作,用于性能评估,而SELECT关注分片优化可用作性能评估的另一个操作;而主从模式下,可将INSERT+SELECT+DELETE作为一组评估性能的

  • go1.6.2 linux/amd64 Ubuntu 16.04 amd64 虚拟机 2 个处理器核心 2 GB 内存 并行测试 BenchmarkParallelHprose2-2 200000 9239 ns/op 789 B/op 25 allocs/op BenchmarkParallelHprose2Unix-2

  • 本文向大家介绍使用FriendFeed来提升MySQL性能的方法,包括了使用FriendFeed来提升MySQL性能的方法的使用技巧和注意事项,需要的朋友参考一下  背景 我们使用MySQL存储了FriendFeed的所有数据。数据库随着用户基数的增长而增长了很多。现在已经存储了超过2.5亿条记录与一堆涵盖了从评论和“喜欢”到好友列表的其他数据。 随着数据的增长,我们也曾迭代地解决了随着如此迅猛的