MySQL優(yōu)化:使用慢查詢?nèi)罩径ㄎ恍瘦^低的SQL語句
MySQL通過慢查詢?nèi)罩?/strong>定位那些執(zhí)行效率較低的SQL 語句,用--log-slow-queries[=file_name]選項啟動時,mysqld 會寫一個包含所有執(zhí)行時間超過long_query_time 秒的SQL語句的日志文件,通過查看這個日志文件定位效率較低的SQL 。
慢查詢?nèi)罩驹诓樵兘Y(jié)束以后才記錄,所以在應(yīng)用反映執(zhí)行效率出現(xiàn)問題的時候查詢慢查詢?nèi)罩静⒉荒芏ㄎ粏栴},可以使用show processlist命令查看當前MySQL在進行的線程,包括線程的狀態(tài)、是否鎖表等,可以實時地查看SQL 的執(zhí)行情況,同時對一些鎖表操作進行優(yōu)化。
下面我們舉例說明一下,如何通過慢查詢?nèi)罩径ㄎ粓?zhí)行效率低的SQL 語句:
開啟慢查詢?nèi)罩?,配置樣?
- [mysqld]
- log-slow-queries
在my.cnf 配置文件中增加上述配置項并重啟mysql服務(wù),這時mysql慢查詢功能生效。慢查詢?nèi)罩緦懭雲(yún)?shù)DATADIR(數(shù)據(jù)目錄)指定的路徑下,默認文件名是host_name-slow.log 。
和錯誤日志、查詢?nèi)罩疽粯?,慢查詢?nèi)罩居涗浀母袷揭彩羌兾谋?,可以被直接讀取。下例中演示了慢查詢?nèi)罩镜脑O(shè)置和讀取過程。
首先查詢一下 long_query_time 的值 。
- mysql> show variables like 'long%';
- +-----------------+-------+
- | Variable_name | Value |
- +-----------------+-------+
- | long_query_time | 10 |
- +-----------------+-------+
- 1 row in set (0.00 sec)
為了方便測試,將修改慢查詢時間為5秒。
- mysql> set long_query_time=5;
- Query OK, 0 rows affected (0.02 sec)
依次執(zhí)行下面兩個查詢語句。
第一個查詢因為查詢時間低于5 秒而不會出現(xiàn)在慢查詢?nèi)罩局校?/p>
- mysql> select count(*) from order2008;
- +----------+
- | count(*) |
- +----------+
- | 208 |
- +----------+
- 1 row in set (0.00 sec)
第二個查詢因為查詢時間大于5 秒而應(yīng)該出現(xiàn)在慢查詢?nèi)罩局校?/p>
- mysql> select count(*) from t_user;
- +----------+
- | count(*) |
- +----------+
- | 6552961 |
查看慢查詢?nèi)罩尽?/p>
- [root@localhost mysql]# more localhost-slow.log
- # Time: 081026 19:46:34
- # User@Host: root[root] @ localhost []
- # Query_time: 11 Lock_time: 0 Rows_sent: 1 Rows_examined: 6552961
- select count(*) from t_user;
從上面日志中,可以發(fā)現(xiàn)查詢時間超過5 秒的SQL,而小于5秒的則沒有出現(xiàn)在此日志中。
#p#
如果慢查詢?nèi)罩局杏涗泝?nèi)容很多,可以使用mysqldumpslow工具(MySQL客戶端安裝自帶)來對慢查詢?nèi)罩具M行分類匯總。下例中對日志文件mysql_master-slow.log進行了分類匯總,只顯示匯總后摘要結(jié)果:
- [root@mysql_master mysql_data]#mysqldumpslow mysql_master-slow.log
- Reading mysql slow query log from mysql_master-slow.log
- Count: 2 Time=11.00s (22s) Lock=0.00s (0s) Rows=1.0 (2), root[root]@mysql_master
- select count(N) from t_user;
對于 SQL 文本完全一致,只是變量不同的語句,mysqldumpslow 將會自動視為同一個語句進行統(tǒng)計,變量值用N來代替。這個統(tǒng)計結(jié)果將大大增加用戶閱讀慢查詢?nèi)罩镜男?,并迅速定位系統(tǒng)的SQL 瓶頸。
注意:慢查詢?nèi)罩緦τ谖覀儼l(fā)現(xiàn)應(yīng)用中有性能問題的SQL很有幫助,建議正常情況下,打開此日志并經(jīng)常查看分析。
【編輯推薦】