qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請訪問 http://qaseven.github.io/

          MySQL數(shù)據(jù)庫基準(zhǔn)壓力測試工具之MySQLSlap使用實例

           一、Mysqlslap介紹

            mysqlslap是MySQL5.1之后自帶的benchmark基準(zhǔn)測試工具,類似Apache Bench負(fù)載產(chǎn)生工具,生成schema,裝載數(shù)據(jù),執(zhí)行benckmark和查詢數(shù)據(jù),語法簡單,靈活,容易使用。該工具可以模擬多個客戶端同時并發(fā)的向服務(wù)器發(fā)出查詢更新,給出了性能測試數(shù)據(jù)而且提供了多種引擎的性能比較。mysqlslap為mysql性能優(yōu)化前后提供了直觀的驗證依據(jù),筆者建議系統(tǒng)運(yùn)維人員應(yīng)該掌握一些常見的壓力測試工具,這樣才能較為準(zhǔn)確的掌握線上系統(tǒng)能夠支撐的用戶流量上限及其抗壓性等問題。

            二、使用方法介紹

            可以使用mysqlslap --help來顯示使用方法:

            1) --concurrency代表并發(fā)數(shù)量,多個可以用逗號隔開,例如:concurrency=10,50,100, 并發(fā)連接線程數(shù)分別是10、50、100個并發(fā)。

            2) --engines代表要測試的引擎,可以有多個,用分隔符隔開。

            3) --iterations代表要運(yùn)行這些測試多少次。

            4) --auto-generate-sql 代表用系統(tǒng)自己生成的SQL腳本來測試。

            5)--auto-generate-sql-load-type 代表要測試的是讀還是寫還是兩者混合的(read,write,update,mixed)

            6) --number-of-queries 代表總共要運(yùn)行多少次查詢。每個客戶端運(yùn)行的查詢數(shù)量可以用查詢總數(shù)/并發(fā)數(shù)來計算。

            7) --debug-info 代表要額外輸出CPU以及內(nèi)存的相關(guān)信息。

            8) --number-int-cols :創(chuàng)建測試表的 int 型字段數(shù)量

            9) --auto-generate-sql-add-autoincrement : 代表對生成的表自動添加auto_increment列,從5.1.18版本開始

            10) --number-char-cols 創(chuàng)建測試表的 char 型字段數(shù)量。

            11) --create-schema 測試的schema,MySQL中schema也就是database。

            12) --query  使用自定義腳本執(zhí)行測試,例如可以調(diào)用自定義的一個存儲過程或者sql語句來執(zhí)行測試。

            13) --only-print 如果只想打印看看SQL語句是什么,可以用這個選項。

            三、Demo實例

            下面我們使用幾個demo實例來進(jìn)行測試

            1、Demo1:

            [root@localhost ~]# mysqlslap -uroot -p123abc --concurrency=100 --iterations=1 --auto-generate-sql --auto-generate-sql-load-type=mixed --auto-generate-sql-add-autoincrement --engine=myisam --number-of-queries=10 --debug-info

            #備注本次測試以100個并發(fā)線程、測試1次,自動生成SQL測試腳本、讀、寫、更新混合測試、自增長字段、測試引擎為myisam、共運(yùn)行10次查詢,輸出cpu資源信息

            返回信息如下所示:

          rement --engine=myisam --number-of-queries=10 --debug-info
          Benchmark
          Running for engine myisam
          Average number of seconds to run all queries: 0.129 seconds
          Minimum number of seconds to run all queries: 0.107 seconds
          Maximum number of seconds to run all queries: 0.264 seconds
          Number of clients running queries: 100
          Average number of queries per client: 0
          User time 0.16, System time 0.25
          Maximum resident set size 4624, Integral resident set size 0
          Non-physical pagefaults 7346, Physical pagefaults 0, Swaps 0
          Blocks in 0 out 0, Messages in 0 out 0, Signals 0
          Voluntary context switches 27221, Involuntary context switches 4241

            2、Demo2:指定數(shù)據(jù)庫和sql語句

            mysqlslap -h192.168.202.84 -P3309 --concurrency=100 --iterations=1 --create-schema='mms_sdmtv' --query='select * from role;' --number-of-queries=10 --debug-info -uroot -p123abc

            #備注使用mysqlslap指定sql語句進(jìn)行測試

            3、Demo3:測試用例

          [root@localhost /]# mysqlslap --concurrency=50,100,200 --iterations=20 --number-int-cols=4 --number-char-cols=35 --auto-generate-sql --auto-generate-sql-add-autoincrement --auto-generate-sql-load-type=read --engine=myisam,innodb --number-of-queries=200 --verbose --socket=/var/lib/mysql/mysql.sock -uroot -p123abc
          #系統(tǒng)腳本測試,增加int型 4列char 型35列,測試2種引擎myisam,innodb讀的性能,分別用50,100,200個客戶端對服務(wù)器進(jìn)行測試總共200個查詢語句 執(zhí)行20次查詢
          Benchmark
          Running for engine myisam
          Average number of seconds to run all queries: 0.666 seconds
          Minimum number of seconds to run all queries: 0.223 seconds
          Maximum number of seconds to run all queries: 4.889 seconds
          Number of clients running queries: 50
          Average number of queries per client: 4
          Benchmark
          Running for engine myisam
          Average number of seconds to run all queries: 0.620 seconds
          Minimum number of seconds to run all queries: 0.231 seconds
          Maximum number of seconds to run all queries: 4.898 seconds
          Number of clients running queries: 100
          Average number of queries per client: 2
          Benchmark
          Running for engine myisam
          Average number of seconds to run all queries: 0.503 seconds
          Minimum number of seconds to run all queries: 0.257 seconds
          Maximum number of seconds to run all queries: 4.269 seconds
          Number of clients running queries: 200
          Average number of queries per client: 1
          Benchmark
          Running for engine innodb
          Average number of seconds to run all queries: 1.049 seconds
          Minimum number of seconds to run all queries: 0.244 seconds
          Maximum number of seconds to run all queries: 5.292 seconds
          Number of clients running queries: 50
          Average number of queries per client: 4
          Benchmark
          Running for engine innodb
          Average number of seconds to run all queries: 0.712 seconds
          Minimum number of seconds to run all queries: 0.246 seconds
          Maximum number of seconds to run all queries: 6.585 seconds
          Number of clients running queries: 100
          Average number of queries per client: 2
          Benchmark
          Running for engine innodb
          Average number of seconds to run all queries: 0.269 seconds
          Minimum number of seconds to run all queries: 0.175 seconds
          Maximum number of seconds to run all queries: 0.328 seconds
          Number of clients running queries: 200
          Average number of queries per client: 1

            4、自建SQL測試用例

            mysqlslap --create=/yourpath/Test1.sql --query=/yourpath/Test2.sql --concurrency=50,100,200 --iterations=20 --engine=myisam,innodb  -u root -p123abc

            #在設(shè)定的yourpath目錄下創(chuàng)建你的測試sql文Test1及Test2并進(jìn)行50、100及200的模擬并發(fā)測試


          posted on 2013-09-13 11:38 順其自然EVO 閱讀(351) 評論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫

          <2013年9月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          導(dǎo)航

          統(tǒng)計

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 文昌市| 东海县| 岳池县| 新干县| 隆尧县| 梅州市| 南投市| 永州市| 晋宁县| 黄骅市| 分宜县| 梅州市| 西昌市| 台山市| 普格县| 广安市| 清新县| 揭西县| 莱西市| 达拉特旗| 凤山市| 中山市| 湘潭市| 岳西县| 托克逊县| 安塞县| 舒城县| 临西县| 柳江县| 松原市| 隆昌县| 舞钢市| 深水埗区| 新泰市| 吴川市| 武川县| 蒙阴县| 丹江口市| 日喀则市| 长治县| 苗栗市|