天天看點

Mysql 慢日志分析工具Mysqldumpslow

   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