標籤:mysql 慢日誌分析
mysqldumpslow是mysql內建的用來分析慢查詢的工具,當然不止這一種工具,還有percona-toolkit是percona公司出的一組命令列工具的集合,用來執行各種通過手工執行非常複雜和麻煩的mysql相關任務,包含以下內容:
檢查master和slave資料一致性/記錄有效歸檔/伺服器資訊匯總/分析和統計日誌,為了省事這塊使用mysqldumpslow命令做分析。
需要開啟mysql的慢查詢日誌,否則無法進行統計分析,開啟mysql慢查詢日誌需要在mysql的設定檔中進行如下配置:
slow_query_log = 1#定義超過1秒的查詢計數到變數Slow_queriesslow-query-log-file = mysql-slow.loglong_query_time = 1
-s,是order的順序
al 平均鎖定時間
ar 平均返回記錄時間
at 平均查詢時間(預設)
c 計數
l 鎖定時間
r 返回記錄
t 查詢時間
-t,是top n的意思,即為返回前面多少條的資料
-g,後邊可以寫一個正則匹配模式,大小寫不敏感的
例:
按照平均查詢時間進行排序,同時取排序的前20個:
以下面這條sql為例:
mysqldumpslow -s at -t 20 mysql-slow.log
Count: 1 Time=19.26s (19s) Lock=0.00s (0s) Rows=1000.0 (1000), kaifa[kaifa]@[10.10.254.2] select cou from ( select count(*) as cou from `foot_step` where is_deleted=N group by user_id ) c order by cou desc LIMIT N, N
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 表示).
本文出自 “螞蟻” 部落格,請務必保留此出處http://215687833.blog.51cto.com/6724358/1908956
Mysql 慢日誌分析