• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    用sysbench来测试MySQL的性能的教程

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

    正如你所看到的的,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脚本!

    您可能感兴趣的文章:
    • Sysbench对Mysql进行基准测试过程解析
    • MySQL数据库基于sysbench实现OLTP基准测试
    • 通过sysbench工具实现MySQL数据库的性能测试的方法
    • sysbench对mysql压力测试的详细教程
    • 使用sysbench来测试MySQL性能的详细教程
    • MySQL性能压力基准测试工具sysbench的使用简介
    上一篇:实例讲解Lua中pair和ipair的区别
    下一篇:Lua中table里内嵌table的例子
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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