首頁  >  文章  >  資料庫  >  關於mysqlslap對mysql進行壓力測試的詳細介紹

關於mysqlslap對mysql進行壓力測試的詳細介紹

黄舟
黄舟原創
2017-06-04 11:55:391041瀏覽

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>#--auto-generate-sql, -a 自動產生測試表和數據,表示用mysqlslap工具自己產生的SQL腳本來測試並發壓力。 <br>--auto-generate-sql-load-type=type 測試語句的型別。代表要測試的環境是讀取操作還是寫入操作還是兩者混合的。取值包括:read,<br>key<a href="http://www.php.cn/wiki/1051.html" target="_blank">,write,up</a>date<a href="http://www.php.cn/wiki/1255.html" target="_blank">和mixed(預設)。 </a>--auto-generate-sql-add-auto-increment 代表對產生的表自動新增auto_increment列,從5.1.18版本開始支援。 <br>--number-char-cols=N, -x N 自動產生的測試表中包含多少個<br>字元類型<a href="http://www.php.cn/code/6739.html" target="_blank">的列,預設1</a>--number-int-cols=N , -y N 自動產生的測試表中包含多少個數字類型的列,預設1<br>--number-of-queries=N 總的測試<br>查詢<a href="http://www.php.cn/php/php-tp-demand.html" target="_blank">次數(並發客戶數×每客戶查詢次數)</a>--query="sql statement",-q 使用自訂腳本執行測試,例如可以呼叫自訂的<br>預存程序<a href="http://www.php.cn/code/12179.html" target="_blank">或sql語句來執行測試。 </a>--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-<br>print<a href="http://www.php.cn/wiki/1362.html" target="_blank"> 只列印測試語句而不實際執行。 </a>--debug-info, -T 列印記憶體和CPU的相關資訊。 <br> 

說明:

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

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

#Demo 1:

單執行緒測試。測試做了什麼。

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

##Demo 2:

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

# mysqlslap -a --concurrency=50,100 --number-of-queries 1000 --iterations=5 --engine=myisam,innodb -uroot -p123456<br> 分別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對mysql進行壓力測試的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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