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

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

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

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

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

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

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

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

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

压力测试前,我们配置一下环境,创建一个用户和数据库。 mysql> create user sysbench_test identified by 'mysql'; Query OK, 0 rows affected (0.08 sec) mysql> create database sysbench_db character set utf8; Query OK, 1 row affected (0.08 sec) mysql> grant all on sysbench_db.* to sysbench_test@'%'; Query OK, 0 rows affected (0.00 sec)

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

#!/usr/bin/env sysbench function event() db_query( "SELECT 1" ) end

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

./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

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

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

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 invalid option: --tbales=8

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

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

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

我们来看看第3个Lua模板,test3.lua function thread_init() drv = sysbench.sql.driver() con = drv:connect() end function event() con:query("SELECT 1" ) end function thread_done() con:disconnect() end

使用命令即可完成测试。

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模板。

原文发布于微信公众号 - 杨建荣的学习笔记(jianrong-notes)

原文发表时间:2017-12-08

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏坚毅的PHP

HBase 异步查询导致的死锁和zookeeper通信中断问题追踪与总结[非技术]

机房T和机房Y共十台前端机,Y机房请求量是T的两倍,主要用于数据查询,开始问题是Y机房tomcat 相继僵死 1) tomcat僵死处理步骤 a 检查代码,发现...

40150
来自专栏Java架构师学习

如何构建一个较为通用的业务技术架构

22050
来自专栏北京马哥教育

我的linux运维日记,比较下学习与工作。

从事运维一年半,遇到过各式各样的问题,数据丢失,网站挂马,误删数据库文件,黑客攻击等各类问题,今天想简单整理一下,主要有以下几点: 1.线上操作规范 测试使用 ...

36670
来自专栏MessageQueue

2017上海QCon之旅总结(中)

本来这个公众号的交流消息中间件相关的技术的。上周去上海参加了QCon,第一次参加这样的技术会议,感受挺多的,所以整理一下自己的一些想法接公众号和大家交流一下。

14030
来自专栏Phoenix的Android之旅

重构-如何编写一段好的代码

关于重构,很多人可能都有惨痛的经验, 就不说去阅读别人的代码了, 有时候自己写的代码过半年,可能自己都看不明白, 这时候再来重构代码是一件很痛苦的事情。

9130
来自专栏用户2442861的专栏

电商搜索引擎实践(工程篇)

随着互联网数据规模的爆炸式增长, 如何从海量的历史, 实时数据中快速获取有用的信息, 变得越来越有挑战性. 一个中等的电商平台, 每天都要产生百万条原始数据,...

68620
来自专栏xingoo, 一个梦想做发明家的程序员

【插件开发】—— 1 Eclipse插件开发导盲

在真正接触eclipse插件开发一个月后,对插件的开发过程以及技术要求,也有了一定的了解。遥想之前像无头苍蝇一样乱撞乱学,真心觉得浪费了不少时间。这里就总结...

41990
来自专栏CSDN技术头条

用最少的钱,实现工程效率实践

研发团队的工程效率实践,现在越来越多的人开始谈论这个话题,但是真真能实操的还本场 Chat 侧重于实践,不会有抽象的概念和理论知识。

18630
来自专栏北京马哥教育

19个心得 明明白白说Linux下的负载均衡

一、目前网站架构一般分成负载均衡层、web层和数据库层,我其实一般还会多加一层,即文件服务器层,因为现在随着网站的PV越来越多,文件服务器的压力也越来越大;不过...

30170
来自专栏数据和云

技术前沿:Oracle 18c 最新特性概览

作者简介 ? Joel Perez Oracle ACE Director,云和恩墨高级云技术专家 自从今年OOW上Oracle宣布要推出18c,一直受到...

446110

扫码关注云+社区

领取腾讯云代金券