自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

MySQL壓力測(cè)試中定制sysbench的Lua模板

數(shù)據(jù)庫(kù) MySQL
sysbench是依舊是我們MySQL壓力測(cè)試的老朋友,這么多年,還依然是主流的測(cè)試工具,自有他流行的道理?;氐蕉ㄖ芁ua模板的部分,如果我們反推Lua的邏輯,和sysbench聯(lián)系起來(lái),我們可能要花上幾倍的代價(jià),不如聽(tīng)聽(tīng)sysbench作者怎么說(shuō)。

對(duì)于sysbench的定制,自己給自己定了一個(gè)小目標(biāo),但是實(shí)踐的時(shí)候發(fā)現(xiàn),難度比想象的要大很多。

都說(shuō)Lua很簡(jiǎn)單,性能很不錯(cuò),但是定制sysbench的模板的時(shí)候,越是深入去看,越覺(jué)得少了一些東西。

這個(gè)時(shí)候我想起了學(xué)習(xí)的周期和復(fù)雜度的一個(gè)說(shuō)法,如果想快速學(xué)習(xí)一門(mén)技術(shù),一種方式是通過(guò)代碼來(lái)理解它的實(shí)現(xiàn),來(lái)反推它的邏輯,這種方式的難度極大,而我前幾天發(fā)現(xiàn)嘗試的就是這種,這種方式非??鄲灒侨绻軌虺料滦膩?lái),看代碼看到一種程度之后,有了感覺(jué)相信就會(huì)融會(huì)貫通了。

還有一種方式,算是捷徑,就是去聽(tīng)聽(tīng)作者怎么說(shuō),通過(guò)他的分享來(lái)從整體對(duì)一個(gè)項(xiàng)目有一個(gè)基本的認(rèn)識(shí)和了解,就好比你去拜訪一個(gè)朋友,他熱情的把你領(lǐng)進(jìn)門(mén),帶著你走走客廳,走走臥室,給你介紹房子的裝修風(fēng)格,里面的家具和電器,為什么要這么設(shè)計(jì),很快你就能夠?qū)@一切熟悉起來(lái)。這種方式很好,而且最省事,但是可遇不可求。

對(duì)于sysbench的學(xué)習(xí)如果有這樣的方式也是極好的,所以我們就可以想辦法找找sysbench作者的心路歷程。自從0.5版本之后,有相當(dāng)長(zhǎng)的一段時(shí)間就沒(méi)有深入維護(hù)了。

而從2016年開(kāi)始,重啟了這個(gè)計(jì)劃。

所以sysbench是依舊是我們MySQL壓力測(cè)試的老朋友,這么多年,還依然是主流的測(cè)試工具,自有他流行的道理。

回到定制Lua模板的部分,如果我們反推Lua的邏輯,和sysbench聯(lián)系起來(lái),我們可能要花上幾倍的代價(jià),不如聽(tīng)聽(tīng)sysbench作者怎么說(shuō)。

壓力測(cè)試前,我們配置一下環(huán)境,創(chuàng)建一個(gè)用戶和數(shù)據(jù)庫(kù)。

  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) 

 

然后配置一個(gè)最簡(jiǎn)單的Lua模板,內(nèi)容如下:

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

 

運(yùn)行的時(shí)候,配置執(zhí)行權(quán)限,chmod +x test1.lua,然后執(zhí)行

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

其中參數(shù)--mysql-user=sysbench_test --mysql-password=mysql --mysql-host=127.0.0.1 --mysql-port=65535是為了連接,如果你是使用3306端口的默認(rèn)配置命令就更簡(jiǎn)單了,輸出如下:

此外我們還可以驗(yàn)證命令選項(xiàng)。我們推出第2個(gè)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.  

 

如果命令選項(xiàng)不對(duì),會(huì)檢查出來(lái)。

  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 

 

如果沒(méi)有問(wèn)題,則可以使用help來(lái)得到初始化后的選項(xiàng)值。

  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] 

 

接下來(lái)就是重點(diǎn)了,關(guān)于SQL API的定制,其實(shí)是有規(guī)則可循的。

我們來(lái)看看第3個(gè)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 

使用命令即可完成測(cè)試。

  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 

后續(xù)繼續(xù)補(bǔ)充更多的Lua模板。 

 

責(zé)任編輯:龐桂玉 來(lái)源: 楊建榮的學(xué)習(xí)筆記
相關(guān)推薦

2017-10-12 10:57:51

MySQL基準(zhǔn)測(cè)試sysbench工具

2021-07-03 08:54:49

LinuxSysbench性能

2010-05-17 13:16:23

MySQL壓力測(cè)試工具

2020-05-18 07:00:00

性能測(cè)試壓力測(cè)試負(fù)載測(cè)試

2011-06-08 16:59:04

性能測(cè)試載測(cè)試壓力測(cè)試

2023-06-06 16:10:11

2012-03-02 11:09:08

壓力測(cè)試

2010-02-23 16:24:47

Visual Stud

2012-02-16 10:18:04

Nginx壓力測(cè)試

2014-06-12 09:02:10

MariaDB壓力測(cè)試

2011-08-30 11:09:26

MySQL ProxyLua

2019-07-22 09:24:54

LinuxMySQL數(shù)據(jù)庫(kù)

2020-07-07 13:00:00

Linux壓力測(cè)試

2015-07-27 18:19:22

Linuxstress參數(shù)

2023-12-08 13:15:00

MySQL數(shù)據(jù)庫(kù)Java

2011-08-30 10:36:31

Ubuntu 9.04Mysql ProxyLua

2010-10-14 09:24:08

Ruby on RaiCakePHP

2009-05-18 08:52:17

壓力測(cè)試Rpplet測(cè)試

2020-06-17 08:55:22

mysqlslapsysbenchMySQL

2019-03-15 09:17:22

Web測(cè)試工具
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)