本總結來自美團內部分享,屏蔽了內部數據與工具mysql
知識準備
索引
- 索引是存儲引擎用於快速找到記錄的一種數據結構
- B-Tree,適用於全鍵值,鍵值範圍或鍵最左前綴:(A,B,C): A, AB, ABC,B,C,BC
- 哪些列建議建立索引:WHERE, JOIN , GROUP BY, ORDER BY等語句使用的列
- 如何選擇索引列的順序:
- 常常被使用到的列優先
- 選擇性高的列優先:選擇性=distinct(col)/count(col)
- 寬度小的列優先:寬度 = 列的數據類型
慢查詢
緣由
- 未使用索引
- 索引不優
- 服務器配置不佳
- 死鎖
- …
命令
看版本
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權限