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
<br>
以上是mysqlslap的使用方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!