MySQL压力测试中定制sysbench的Lua模板

对于sysbench的定制,自己给自己定了一个小目标,但是实践的时候发现,难度比想象的要大很多。

十年的增城网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整增城建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联从事“增城网站设计”,“增城网站推广”以来,每个客户项目都认真落实执行。

都说Lua很简单,性能很不错,但是定制sysbench的模板的时候,越是深入去看,越觉得少了一些东西。

这个时候我想起了学习的周期和复杂度的一个说法,如果想快速学习一门技术,一种方式是通过代码来理解它的实现,来反推它的逻辑,这种方式的难度极大,而我前几天发现尝试的就是这种,这种方式非常苦闷,但是如果能够沉下心来,看代码看到一种程度之后,有了感觉相信就会融会贯通了。

还有一种方式,算是捷径,就是去听听作者怎么说,通过他的分享来从整体对一个项目有一个基本的认识和了解,就好比你去拜访一个朋友,他热情的把你领进门,带着你走走客厅,走走卧室,给你介绍房子的装修风格,里面的家具和电器,为什么要这么设计,很快你就能够对这一切熟悉起来。这种方式很好,而且最省事,但是可遇不可求。

对于sysbench的学习如果有这样的方式也是极好的,所以我们就可以想办法找找sysbench作者的心路历程。自从0.5版本之后,有相当长的一段时间就没有深入维护了。

而从2016年开始,重启了这个计划。

所以sysbench是依旧是我们MySQL压力测试的老朋友,这么多年,还依然是主流的测试工具,自有他流行的道理。

回到定制Lua模板的部分,如果我们反推Lua的逻辑,和sysbench联系起来,我们可能要花上几倍的代价,不如听听sysbench作者怎么说。

压力测试前,我们配置一下环境,创建一个用户和数据库。

 
 
 
  1. mysql> create user sysbench_test identified by 'mysql';
  2. Query OK, 0 rows affected (0.08 sec)
  3. mysql> create database sysbench_db character set utf8;
  4. Query OK, 1 row affected (0.08 sec)
  5. mysql> grant all on sysbench_db.* to sysbench_test@'%';
  6. Query OK, 0 rows affected (0.00 sec)

然后配置一个最简单的Lua模板,内容如下:

 
 
 
  1. #!/usr/bin/env sysbench
  2. function event()
  3.   db_query(
  4. "SELECT 1"
  5. )
  6. end

运行的时候,配置执行权限,chmod +x test1.lua,然后执行

 
 
 
  1. ./test1.lua  --mysql-user=sysbench_test --mysql-password=mysql --mysql-host=127.0.0.1 --mysql-port=65535 --mysql-db=sysbench_db run

其中参数--mysql-user=sysbench_test --mysql-password=mysql --mysql-host=127.0.0.1 --mysql-port=65535是为了连接,如果你是使用3306端口的默认配置命令就更简单了,输出如下:

此外我们还可以验证命令选项。我们推出第2个Lua模板 test2.lua

 
 
 
  1. sysbench.cmdline.options = {
  2.   tables = {"Number of tables", 1},
  3.   table_size = {"Number of rows per table", 10000},
  4.   create_secondary = {"Create a secondary key", true}
  5. }

如果命令选项不对,会检查出来。

 
 
 
  1. sysbench --tbales=8 test2.lua --mysql-user=sysbench_test --mysql-password=mysql --mysql-host=127.0.0.1 --mysql-port=65535 --mysql-db=sysbench_db run
  2. invalid option: --tbales=8

如果没有问题,则可以使用help来得到初始化后的选项值。

 
 
 
  1. #  sysbench test2.lua help
  2. sysbench 1.0.3 (using bundled LuaJIT 2.1.0-beta2)
  3. test2.lua options:
  4.   --table_size=N              Number of rows per table [10000]
  5.   --tables=N                  Number of tables [1]
  6.   --create_secondary[=on|off] Create a secondary key [on]

接下来就是重点了,关于SQL API的定制,其实是有规则可循的。

我们来看看第3个Lua模板,test3.lua

 
 
 
  1. function thread_init()
  2.   drv = sysbench.sql.driver()
  3.   con = drv:connect()
  4. end
  1. function event()
  2.   con:query("SELECT 1"
  3. )
  4. end
  1. function thread_done()
  2.   con:disconnect()
  3. end

使用命令即可完成测试。

 
 
 
  1. sysbench  test3.lua --mysql-user=sysbench_test --mysql-password=mysql --mysql-host=127.0.0.1 --mysql-port=65535 --mysql-db=sysbench_db run

后续继续补充更多的Lua模板。

当前题目:MySQL压力测试中定制sysbench的Lua模板
标题来源:http://www.csdahua.cn/qtweb/news15/399015.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网