Mysql 慢日誌分析

來源:互聯網
上載者:User

標籤: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 慢日誌分析

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.