首頁  >  文章  >  資料庫  >  mysqlslap的使用方法介紹

mysqlslap的使用方法介紹

PHP中文网
PHP中文网原創
2017-06-21 16:15:281771瀏覽

mysqlslap是從5.1.4版開始的一個MySQL官方提供的壓力測試工具。透過模擬多個並發客戶端存取MySQL來執行壓力測試,並且能很好的對比多個儲存引擎在相同環境下的並發壓力效能差異。

mysqlslap的運行有以下3個步驟:<br>1. 建立schema、table、test data 等,使用單一連接(在MySQL中,schema就是database);<br>2. 執行負載測試,可以使用多個並發客戶端連線;<br>3. 測試環境清理(刪除已建立的資料、表格等,斷開連線),使用單一連線。

 

使用語法如下:<br># mysqlslap [options]

常用參數[options] 詳細說明: <br><br>--auto-generate-sql, -a 自動產生測試表和數據,表示用mysqlslap工具自己產生的SQL腳本來測試並發壓力。 <br>--auto-generate-sql-load-type=type 測試語句的型別。代表要測試的環境是讀取操作還是寫入操作還是兩者混合的。取值包括:read,key,write,update和mixed(預設)。 <br>--auto-generate-sql-add-auto-increment 代表對產生的表自動新增auto_increment列,從5.1.18版本開始支援。 <br>--number-char-cols=N, -x N 自動產生的測試表中包含多少個字元類型的列,預設1<br>--number-int-cols=N, -y N 自動生成的測試表中包含多少個數字類型的列,預設1<br>--number-of-queries=N 總的測試查詢次數(並發客戶數×每客戶查詢次數)<br>--query="sql statement",-q 使用自訂腳本執行測試,例如可以呼叫自訂的預存程序或sql語句來執行測試。 <br>--create="sql statement" 建立表格的SQL語句或檔案<br>--concurrency=N, -c N 表示並發量,也就是模擬多少個客戶端同時執行select。可指定多個值,以逗號或--delimiter參數指定的值做為分隔符號。例如:--concurrency=100,200,500。 <br>--engine=engine_name, -e engine_name 代表要測試的引擎,可以有多個,用分隔符號隔開。例如:--engines=myisam,innodb。 <br>--iterations=N, -i N 測試執行的迭代次數,代表要在不同並發環境下,各自執行測試多少次。 <br>--only-print 只列印測試語句而不實際執行。 <br>--debug-info, -T 列印記憶體和CPU的相關資訊。 <br>

更詳細的參數請查閱官網文件:

 

說明:<br>測試的過程需要產生測試表,插入測試數據,這個mysqlslap可以自動生成,預設產生一個mysqlslap的schema,如果已經存在則先刪除。可以用--only-print來列印實際的測試過程,整個測試完成後不會在資料庫中留下痕跡。

 

各種測試參數實例(-p後面接的是mysql的root密碼):

<br>Demo 1:

單執行緒測試。測試做了什麼。 <br># mysqlslap -a -uroot -p123456<br>多執行緒測試。使用–concurrency來模擬客戶端並發連線數。如,100個客戶端並發連接資料庫。 <br># mysqlslap -a -c 100 -uroot -p123456<br>迭代測試。用於需要多次執行測試得到平均值。如,迭代10次,取平均值。 <br># mysqlslap -a -i 10 -uroot -p123456<br>

##Demo 2:<br>

#測試同時不同的儲存引擎的效能進行比較:

<br># mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --iterations=5 --engine=myisam,innodb -uroot -p123456

分別500個並發,每個並發客戶端執行一次查詢,共500次查詢,和1000個並發,每個並發客戶端執行一次查詢,共1000次查詢。為了精確起見,可以多迭代測試幾次:

<br>

兩個測試都會自動產生SQL測試腳本,各自迭代10次取平均值。測試環境包括讀取、寫入、更新混合測試,自增長場、測試引擎為innodb。

# mysqlslap –uroot –p –concurrency=500  –I 10 –a –auto-generate-sql-type=mixed –auto-generate-sql-add-autoincrement –engine=innodb –number-of- queries=500

# mysqlslap –uroot –p –concurrency=1000  –I 10 –a –auto-generate-sql-type=mixed –auto-generate-sql-add-autoincrement –engine=innodb –number -of-queries=1000

回傳結果如下:

#從上面兩個測驗可以看出來,並發量從500變成1000的時候,查詢時間大概接近原來的一倍左右。

以上是mysqlslap的使用方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn