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>
<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中文網其他相關文章!