天天看點

MySQL慢查詢日志總結

<b>慢查詢日志概念</b>

     MySQL的慢查詢日志是MySQL提供的一種日志記錄,它用來記錄在MySQL中響應時間超過閥值的語句,具體指運作時間超過long_query_time值的SQL,則會被記錄到慢查詢日志中。long_query_time的預設值為10,意思是運作10S以上的語句。預設情況下,Mysql資料庫并不啟動慢查詢日志,需要我們手動來設定這個參數,當然,如果不是調優需要的話,一般不建議啟動該參數,因為開啟慢查詢日志會或多或少帶來一定的性能影響。慢查詢日志支援将日志記錄寫入檔案,也支援将日志記錄寫入資料庫表。

官方文檔,關于慢查詢的日志介紹如下(部分資料,具體參考官方相關連結):

The slow query log consists of SQL statements that took more than long_query_time seconds to execute and required at least min_examined_row_limit rows to be examined. The minimum and default values of long_query_time are 0 and 10, respectively. The value can be specified to a resolution of microseconds. For logging to a file, times are written including the microseconds part. For logging to tables, only integer times are written; the microseconds part is ignored.

By default, administrative statements are not logged, nor are queries that do not use indexes for lookups. This behavior can be changed usinglog_slow_admin_statements and log_queries_not_using_indexes, as described later.

<b></b>

<b>慢查詢日志相關參數</b>

MySQL 慢查詢的相關參數解釋:

slow_query_log    :是否開啟慢查詢日志,1表示開啟,0表示關閉。

log-slow-queries  :舊版(5.6以下版本)MySQL資料庫慢查詢日志存儲路徑。可以不設定該參數,系統則會預設給一個預設的檔案host_name-slow.log

slow-query-log-file:新版(5.6及以上版本)MySQL資料庫慢查詢日志存儲路徑。可以不設定該參數,系統則會預設給一個預設的檔案host_name-slow.log

long_query_time :慢查詢門檻值,當查詢時間多于設定的門檻值時,記錄日志。

log_queries_not_using_indexes:未使用索引的查詢也被記錄到慢查詢日志中(可選項)。

log_output:日志存儲方式。log_output='FILE'表示将日志存入檔案,預設值是'FILE'。log_output='TABLE'表示将日志存入資料庫,這樣日志資訊就會被寫入到mysql.slow_log表中。MySQL資料庫支援同時兩種日志存儲方式,配置的時候以逗号隔開即可,如:log_output='FILE,TABLE'。日志記錄到系統的專用日志表中,要比記錄到檔案耗費更多的系統資源,是以對于需要啟用慢查詢日志,又需要能夠獲得更高的系統性能,那麼建議優先記錄到檔案。

<b>慢查詢日志配置</b>

預設情況下slow_query_log的值為OFF,表示慢查詢日志是禁用的,可以通過設定slow_query_log的值來開啟,如下所示:

使用set global slow_query_log=1開啟了慢查詢日志隻對目前資料庫生效,如果MySQL重新開機後則會失效。如果要永久生效,就必須修改配置檔案my.cnf(其它系統變量也是如此)。例如如下所示:

<a href="http://images2015.cnblogs.com/blog/73542/201606/73542-20160617103909307-1609687176.png"></a>

修改my.cnf檔案,增加或修改參數slow_query_log 和slow_query_log_file後,然後重新開機MySQL伺服器,如下所示

slow_query_log =1

slow_query_log_file=/tmp/mysql_slow.log

<a href="http://images2015.cnblogs.com/blog/73542/201606/73542-20160617103910792-1461641801.png"></a>

關于慢查詢的參數slow_query_log_file ,它指定慢查詢日志檔案的存放路徑,系統預設會給一個預設的檔案host_name-slow.log(如果沒有指定參數slow_query_log_file的話)

那麼開啟了慢查詢日志後,什麼樣的SQL才會記錄到慢查詢日志裡面呢? 這個是由參數long_query_time控制,預設情況下long_query_time的值為10秒,可以使用指令修改,也可以在my.cnf參數裡面修改。關于運作時間正好等于long_query_time的情況,并不會被記錄下來。也就是說,在mysql源碼裡是判斷大于long_query_time,而非大于等于。從MySQL 5.1開始,long_query_time開始以微秒記錄SQL語句運作時間,之前僅用秒為機關記錄。如果記錄到表裡面,隻會記錄整數部分,不會記錄微秒部分。

如上所示,我修改了變量long_query_time,但是查詢變量long_query_time的值還是10,難道沒有修改到呢?注意:使用指令 set global long_query_time=4修改後,需要重新連接配接或新開一個會話才能看到修改值。你用show variables like 'long_query_time'檢視是目前會話的變量值,你也可以不用重新連接配接會話,而是用show global variables like 'long_query_time'; 如下所示:

<a href="http://images2015.cnblogs.com/blog/73542/201606/73542-20160617103913010-1077070212.png"></a>

在MySQL裡面執行下面SQL語句,然後我們去檢查對應的慢查詢日志,就會發現類似下面這樣的資訊。

MySQL慢查詢日志總結

log_output 參數是指定日志的存儲方式。log_output='FILE'表示将日志存入檔案,預設值是'FILE'。log_output='TABLE'表示将日志存入資料庫,這樣日志資訊就會被寫入到mysql.slow_log表中。MySQL資料庫支援同時兩種日志存儲方式,配置的時候以逗号隔開即可,如:log_output='FILE,TABLE'。日志記錄到系統的專用日志表中,要比記錄到檔案耗費更多的系統資源,是以對于需要啟用慢查詢日志,又需要能夠獲得更高的系統性能,那麼建議優先記錄到檔案。

系統變量log-queries-not-using-indexes:未使用索引的查詢也被記錄到慢查詢日志中(可選項)。如果調優的話,建議開啟這個選項。另外,開啟了這個參數,其實使用full index scan的sql也會被記錄到慢查詢日志。

This option does not necessarily mean that no index is used. For example, a query that uses a full index scan uses an index but would be logged because the index would not limit the number of rows.

系統變量log_slow_admin_statements表示是否将慢管理語句例如ANALYZE TABLE和ALTER TABLE等記入慢查詢日志

系統變量log_slow_slave_statements 表示

By default, a replication slave does not write replicated queries to the slow query log. To change this, use thelog_slow_slave_statements system variable.

When the slow query log is enabled, this variable enables logging for queries that have taken more than long_query_time seconds to execute on the slave. This variable was added in MySQL 5.7.1. Setting this variable has no immediate effect. The state of the variable applies on all subsequent START SLAVE statements.

The server writes less information to the slow query log if you use the --log-short-format option.

Command-Line Format

<code>--log-short-format</code>

Permitted Values

Type

<code>boolean</code>

Default

<code>FALSE</code>

另外,如果你想查詢有多少條慢查詢記錄,可以使用系統變量。

<b></b> 

<b>日志分析工具</b><b>mysqldumpslow </b>

在生産環境中,如果要手工分析日志,查找、分析SQL,顯然是個體力活,MySQL提供了日志分析工具mysqldumpslow

檢視mysqldumpslow的幫助資訊:

-s, 是表示按照何種方式排序,

c: 通路計數 l: 鎖定時間 r: 傳回記錄 t: 查詢時間 al:平均鎖定時間 ar:平均傳回記錄數 at:平均查詢時間

-t, 是top n的意思,即為傳回前面多少條的資料;

-g, 後邊可以寫一個正則比對模式,大小寫不敏感的;

比如

得到傳回記錄集最多的10個SQL。

mysqldumpslow -s r -t 10 /database/mysql/mysql06_slow.log

得到通路次數最多的10個SQL

mysqldumpslow -s c -t 10 /database/mysql/mysql06_slow.log

得到按照時間排序的前10條裡面含有左連接配接的查詢語句。

mysqldumpslow -s t -t 10 -g “left join” /database/mysql/mysql06_slow.log

另外建議在使用這些指令時結合 | 和more 使用 ,否則有可能出現刷屏的情況。

mysqldumpslow -s r -t 20 /mysqldata/mysql/mysql06-slow.log | more

參考資料:

https://dev.mysql.com/doc/refman/5.7/en/slow-query-log.html

https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_long_query_time