轉 MySQL問題排查工具介紹

原文連接: http://mrchenatu.com/2017/03/24/mysql-tool/

本總結來自美團內部分享,屏蔽了內部數據與工具mysql

知識準備

索引

  • 索引是存儲引擎用於快速找到記錄的一種數據結構
  • B-Tree,適用於全鍵值,鍵值範圍或鍵最左前綴:(A,B,C): A, AB, ABC,B,C,BC
  • 哪些列建議建立索引:WHERE, JOIN , GROUP BY, ORDER BY等語句使用的列
  • 如何選擇索引列的順序:
    1. 常常被使用到的列優先
    2. 選擇性高的列優先:選擇性=distinct(col)/count(col)
    3. 寬度小的列優先:寬度 = 列的數據類型

慢查詢

緣由

  1. 未使用索引
  2. 索引不優
  3. 服務器配置不佳
  4. 死鎖

命令

看版本

mysql -V 客戶端版本 select version 服務器版本sql

explain 執行計劃,慢查詢分析神器
  • type緩存

    • const,system: 最多匹配一個行,使用主鍵或者unique進行索引
    • eq_ref: 返回一行數據,一般在聯接時出現,使用主鍵或者unique索引(內表索引鏈接類型)
    • ref: 使用key的最左前綴,且key不是主鍵或unique鍵
    • range: 索引範圍掃描,對索引的掃面開始於某一點,返回匹配的行
    • index:以索引的順序進行全表掃描,優勢是不用排序,缺點是還要全表掃描
    • all: 全表掃描 no no no
  • extra服務器

    • using index : 索引覆蓋,只用到索引,能夠避免訪問表
    • using where: 在存儲引擎檢索行後再作過濾
    • using temporary:使用臨時表,一般在使用GROUP BY,ORDER BY 時出現(嚴禁)
    • using filesort: 到非索引順序的額外排序,當order by col未使到索引時發生(嚴禁)
  • possible_keys: 顯示查詢可能使用的索引
  • key:優化器決定採用哪一個索引來優化對該表的訪問
  • rows:MySQL估算的爲了找到所需行要檢索的數,優化選擇key的參考 (不是結果集的行數)
  • key_len: 使用的索引左前綴的長度(字節數),亦可理解爲使用了索引中哪些字段
    • 定長字段,int佔4個字節、date佔3個字節、timestamp佔4個字節,char(n)佔n個字節
    • NULL的字段:須要加1個字節,所以建議盡亮設計爲NOT NULL
    • 變長字段varchar(n),則須要 (n 編碼字符所佔字節數 + 2 、)個字節,如utf8編碼的, 個字符
      佔 3個字節,則 度爲 n 
      3 + 2
  • 強制使用索引: USE INDEX (建議)或 FORCE_INDEX (強制)

SHOW 命令

  • show status
    • 查看select語句的執行數 show global status like ‘Com_select’;
    • 查看慢查詢的個數 show global status like ‘Slow_queries’;
    • 表掃描狀況 show global status like ‘Handler_read%’; Handler_read_rnd_next / com_select > 4000 須要考慮優化索引
  • show variables
    • 查看慢查詢相關的配置 show variables like ‘long_query_time’;
    • 將慢查詢時間線設置爲2s set global long_query_time=2;
    • 查看InnoDB緩存 show variables like ‘innodb_buffer_pool_size’;
    • 查看InnoDB緩存的使用狀態 show status like ‘Innodb_bufferpool%’; 緩存命中率=(1-Innodb_buffer_pool_reads/ Innodb_buffer_pool_read_requests) 100%;緩存率=(Innodb_buffer_pool_pages_data/ Innodb_buffer_pool_pages_total)100%
    • SHOW PROFILES;該命令能夠trace在整個執行過程當中各資源消耗狀況(會話級)
    • SHOW PROCESSLIST; 查看當前有哪些線程正在運行,而且處在何種狀態
    • SHOW ENGINE INNODB STATUS; 可用於分析死鎖,但須要super權限
相關文章
相關標籤/搜索