您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“MySQL慢日志的相關(guān)配置”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“MySQL慢日志的相關(guān)配置”吧!
slow_query_log #是否開啟慢查詢?nèi)罩荆?表示開啟,0表示關(guān)閉 log_slow_queries #舊版(5.6以下版本)MySQL數(shù)據(jù)庫慢查詢?nèi)罩敬鎯β窂?。可以不設(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.log(參數(shù)已過時(shí)) slow_query_log_file #新版(5.6及以上版本)MySQL數(shù)據(jù)庫慢查詢?nèi)罩敬鎯β窂???梢圆辉O(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.log(替換log_slow_queries) long_query_time #慢查詢閾值,默認(rèn)為10s,當(dāng)查詢時(shí)間多于設(shè)定的閾值時(shí),記錄日志 log_queries_not_using_indexes #未使用索引的查詢也被記錄到慢查詢?nèi)罩局校蛇x項(xiàng)) log_output #日志存儲方式。log_output='FILE'表示將日志存入文件,默認(rèn)值是'FILE'。log_output='TABLE'表示將日志存入數(shù)據(jù)庫,這樣日志信息就會(huì)被寫入到mysql.slow_log表中。MySQL數(shù)據(jù)<br>庫支持同時(shí)兩種日志存儲方式,配置的時(shí)候以逗號隔開即可,如:log_output='FILE,TABLE'。日志記錄到系統(tǒng)的專用日志表中,要比記錄到文件耗費(fèi)更多的系統(tǒng)資源,因此對于需要啟用慢查詢?nèi)罩?,又?lt;br>要能夠獲得更高的系統(tǒng)性能,那么建議優(yōu)先記錄到文件
慢日志配置 默認(rèn)情況下slow_query_log的值為OFF,表示慢查詢?nèi)罩臼墙玫?,可以通過設(shè)置slow_query_log的值來開啟,如下所示: mysql> show variables like '%slow_query_log%'; +---------------------+------------------------------------------+ | Variable_name | Value | +---------------------+------------------------------------------+ | slow_query_log | OFF | | slow_query_log_file | /usr/local/mysql/data/localhost-slow.log | +---------------------+------------------------------------------+ 2 rows in set (0.00 sec) mysql> set global slow_query_log=1; Query OK, 0 rows affected (0.00 sec) mysql> show variables like '%slow_query_log%'; +---------------------+------------------------------------------+ | Variable_name | Value | +---------------------+------------------------------------------+ | slow_query_log | ON | | slow_query_log_file | /usr/local/mysql/data/localhost-slow.log | +---------------------+------------------------------------------+ 2 rows in set (0.00 sec) #使用set global slow_query_log=1開啟了慢查詢?nèi)罩局粚Ξ?dāng)前數(shù)據(jù)庫生效,MySQL重啟后則會(huì)失效。如果要永久生效,就必須修改配置文件my.cnf(其它系統(tǒng)變量也是如此) 修改my.cnf文件,增加或修改參數(shù)slow_query_log 和slow_query_log_file后,然后重啟MySQL服務(wù)器,如下所示: slow_query_log =1 slow_query_log_file=/usr/local/mysql/data/localhost-slow.log mysql> show variables like 'slow_query%'; +---------------------+---------------------+ | Variable_name | Value | +---------------------+---------------------+ | slow_query_log | ON | | slow_query_log_file | /usr/local/mysql/data/localhost-slow.log | +---------------------+---------------------+ rows in set (0.00 sec) mysql> #慢查詢的參數(shù)slow_query_log_file ,它指定慢查詢?nèi)罩疚募拇娣怕窂?,系統(tǒng)默認(rèn)會(huì)給一個(gè)缺省的文件host_name-slow.log
mysql自帶的慢日志分析工具 mysqldumpslow --help Usage: mysqldumpslow [ OPTS... ] [ LOGS... ] Parse and summarize the MySQL slow query log. Options are --verbose verbose --debug debug --help write this text to standard output -v verbose -d debug -s ORDER what to sort by (al, at, ar, c, l, r, t), 'at' is default al: average lock time ar: average rows sent at: average query time c: count l: lock time r: rows sent t: query time -r reverse the sort order (largest last instead of first) -t NUM just show the top n queries -a don't abstract all numbers to N and strings to 'S' -n NUM abstract numbers with at least n digits within names -g PATTERN grep: only consider stmts that include this string -h HOSTNAME hostname of db server for *-slow.log filename (can be wildcard), default is '*', i.e. match all -i NAME name of server instance (if using mysql.server startup script) -l don't subtract lock time from total time ############################################################################## -s, 是表示按照何種方式排序 c: 訪問計(jì)數(shù) l: 鎖定時(shí)間 r: 返回記錄 t: 查詢時(shí)間 al:平均鎖定時(shí)間 ar:平均返回記錄數(shù) at:平均查詢時(shí)間 -t, 是top n的意思,即為返回前面多少條的數(shù)據(jù); -g, 后邊可以寫一個(gè)正則匹配模式,大小寫不敏感的; 比如: 得到返回記錄集最多的10個(gè)SQL。 mysqldumpslow -s r -t 10 /database/mysql/mysql06_slow.log 得到訪問次數(shù)最多的10個(gè)SQL mysqldumpslow -s c -t 10 /database/mysql/mysql06_slow.log 得到按照時(shí)間排序的前10條里面含有左連接的查詢語句。 mysqldumpslow -s t -t 10 -g “l(fā)eft join” /database/mysql/mysql06_slow.log 另外建議在使用這些命令時(shí)結(jié)合 | 和more 使用 ,否則有可能出現(xiàn)刷屏的情況。 mysqldumpslow -s r -t 20 /mysqldata/mysql/mysql06-slow.log | more ##############################################################################
清理mysql-bin 命令行: reset master; reset slave; 針對主從場景 配置my.cnf: log-bin = mysql-bin #可注釋掉 binlog_format = mixed #binlog記錄的模式 expire_logs_days = 7 #設(shè)置保留天數(shù) 重啟mysql生效
到此,相信大家對“MySQL慢日志的相關(guān)配置”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。