mysqldumpslow是mysql自帶的用來分析慢查詢的工具,當然不止這一種工具,還有percona-toolkit是percona公司出的一組指令行工具的集合,用來執行各種通過手工執行非常複雜和麻煩的mysql相關任務,包含以下内容:
檢查master和slave資料一緻性/記錄有效的歸檔/伺服器資訊彙總/分析和統計日志,為了省事這塊使用mysqldumpslow指令做分析。
需要開啟mysql的慢查詢日志,否則無法進行統計分析,開啟mysql慢查詢日志需要在mysql的配置檔案中進行如下配置:
1
2
3
<code>slow_query_log = 1</code><code>#定義超過1秒的查詢計數到變量Slow_queries</code>
<code>slow-query-log-</code><code>file</code> <code>= mysql-slow.log</code>
<code>long_query_time = 1</code>
-s,是order的順序
al 平均鎖定時間
ar 平均傳回記錄時間
at 平均查詢時間(預設)
c 計數
l 鎖定時間
r 傳回記錄
t 查詢時間
-t,是top n的意思,即為傳回前面多少條的資料
-g,後邊可以寫一個正則比對模式,大小寫不敏感的
例:
按照平均查詢時間進行排序,同時取排序的前20個:
以下面這條sql為例:
<code>mysqldumpslow -s at -t 20 mysql-slow.log</code>
4
5
<code>Count: 1 Time=19.26s (19s) Lock=0.00s (0s) Rows=1000.0 (1000), kaifa[kaifa]@[10.10.254.2]</code>
<code> </code><code>select</code> <code>cou from (</code>
<code> </code><code>select</code> <code>count(*) as cou from `foot_step` where is_deleted=N group by user_id </code>
<code> </code><code>) c order by cou desc</code>
<code> </code><code>LIMIT N, N</code>
Count:sql出現的次數占slow_log的百分比:1次
Time: sql執行到傳回的時間長為:19s
(19s):這條sql執行的總時間19s
Lock:鎖時間為0s
Rows=1000.0:發送給用戶端1000行
(1000):總共掃描掃到1000行
後面的是sql本身:賬号、sql語句。
優化建議:sql中已經含有limit取值段,可以再加點條件過濾更精确,如時間段。
主要功能是, 統計不同慢sql的
出現次數(Count),
執行最長時間(Time),
累計總耗費時間(Time),
等待鎖的時間(Lock),
發送給用戶端的行總數(Rows),
掃描的行總數(Rows),
使用者以及sql語句本身(抽象了一下格式, 比如 limit 1, 20 用 limit N,N 表示).
本文轉自青衫解衣 51CTO部落格,原文連結:http://blog.51cto.com/215687833/1908956