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

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

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

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

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

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

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

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

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

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

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

 

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

  1. #!/usr/bin/env sysbench 
  2.  
  3. function event() 
  4.  
  5.   db_query( 
  6.  
  7. "SELECT 1" 
  8.  
  9.  
  10. 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.  
  3.   tables = {"Number of tables", 1}, 
  4.  
  5.   table_size = {"Number of rows per table", 10000}, 
  6.  
  7.   create_secondary = {"Create a secondary key"true
  8.  

 

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

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

 

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

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

 

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

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

 

  1. function thread_init() 
  2.  
  3.   drv = sysbench.sql.driver() 
  4.  
  5.   con = drv:connect() 
  6.  
  7. end 

 

  1. function event() 
  2.  
  3.   con:query(“SELECT 1” 
  4.  
  5.  
  6. end 
  1. function thread_done() 
  2.  
  3.   con:disconnect() 
  4.  
  5. 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模板。 

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/234770.html<

(0)
运维的头像运维
上一篇2025-04-21 06:03
下一篇 2025-04-21 06:05

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注