您好,登錄后才能下訂單哦!
怎么在MySQL中使用慢日志?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
慢日志全稱為慢查詢日志(Slow Query Log),主要用來記錄在 MySQL 中執行時間超過指定時間的 SQL 語句。通過慢查詢日志,可以查找出哪些語句的執行效率低,以便進行優化。
默認情況下,MySQL 并沒有開啟慢日志,可以通過修改 slow_query_log 參數來打開慢日志。與慢日志相關的參數介紹如下:
slow_query_log:是否啟用慢查詢日志,默認為0,可設置為0、1,1表示開啟。
slow_query_log_file:指定慢查詢日志位置及名稱,默認值為host_name-slow.log,可指定絕對路徑。
long_query_time:慢查詢執行時間閾值,超過此時間會記錄,默認為10,單位為s。
log_output:慢查詢日志輸出目標,默認為file,即輸出到文件。
log_timestamps:主要是控制 error log、slow log、genera log 日志文件中的顯示時區,默認使用UTC時區,建議改為 SYSTEM 系統時區。
log_queries_not_using_indexes:是否記錄所有未使用索引的查詢語句,默認為off。
min_examined_row_limit:對于查詢掃描行數小于此參數的SQL,將不會記錄到慢查詢日志中,默認為0。
log_slow_admin_statements:慢速管理語句是否寫入慢日志中,管理語句包含 alter table、create index 等,默認為 off 即不寫入。
一般情況下,我們只需開啟慢日志記錄,配置下閾值時間,其余參數可按默認配置。對于閾值時間,可靈活調整,比如說可以設置為 1s 或 3s 。
在配置文件中,我們可以設置以下幾個慢日志相關參數:
# 慢查詢日志相關配置,可根據實際情況修改 vim /etc/my.cnf [mysqld] slow_query_log = 1 slow_query_log_file = /data/mysql/logs/slow.log long_query_time = 1 log_timestamps = SYSTEM log_output = FILE
下面我們具體看下,慢日志會記錄哪些內容?我們執行一條較慢的查詢 SQL ,來看下在慢日志中的體現。
# 該條SQL執行時間超過閾值 # Time: 2021-05-13T17:38:03.687811+08:00 # User@Host: root[root] @ [192.168.85.0] Id: 2604943 # Query_time: 1.099889 Lock_time: 0.000144 Rows_sent: 39 Rows_examined: 45305 SET timestamp=1620898683; select * from test_table where col_name like '%測試%';
如果啟用了慢速查詢日志,并且選擇了 FILE 作為輸出目標,則寫入日志的每個語句都以 # 字符開頭。對于每一組慢SQL,第一行記錄的是該條 SQL 執行的時刻(如果 log_timestamps 參數為 UTC ,則改時間會顯示 UTC 時區時間),第二行記錄的是執行該語句的用戶和 IP 以及鏈接 id ,第三行的幾個字段解釋如下:
Query_time: duration 語句執行時間,以秒為單位。
Lock_time: duration 獲取鎖的時間(以秒為單位)。
Rows_sent: N 發送給 Client 端的行數。
Rows_examined: N 服務器層檢查的行數(不計算存儲引擎內部的任何處理)。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。