日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL数据库:通用查询日志和慢查询日志分析

發(fā)布時(shí)間:2024/9/30 数据库 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL数据库:通用查询日志和慢查询日志分析 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

MySQL中的日志包括:通用查詢?nèi)罩尽⒙樵內(nèi)罩尽㈠e(cuò)誤日志、二進(jìn)制日志等等。這里主要記錄一下兩種比較常用的日志:通用查詢?nèi)罩竞吐樵內(nèi)罩尽?/p>

(1)通用查詢?nèi)罩?#xff1a;記錄建立的客戶端連接和執(zhí)行的語句。

(2)慢查詢?nèi)罩?#xff1a;記錄所有執(zhí)行時(shí)間超過long_query_time 秒的所有查詢或者不使用索引的查詢。

?

一、通用查詢?nèi)罩?#xff1a;

1、查看當(dāng)前通用日志查詢是否開啟:

?show variables like '%general%';

?

?如果general_log 的值為ON則為開啟,為OFF則為關(guān)閉(默認(rèn)關(guān)閉)

2、查看通用日志的輸出格式:

show variables like ‘%log_output%’;

?

通用查詢?nèi)罩据敵龅母袷娇梢允荈ILE(存儲(chǔ)在數(shù)據(jù)庫的數(shù)據(jù)文件中的hostname.log),也可以是TABLE(存儲(chǔ)在數(shù)據(jù)庫中的mysql.general_log)

3、開啟MySQL通用查詢?nèi)罩?與 設(shè)置通用日志輸出方式:

set global general_log=on;? ##開啟通用日志查詢

set global general_log=off;? ##關(guān)閉通用日志查詢

set global log_output='File;? ##設(shè)置通用日志文件輸出為文件方式

set global log_output='TABLE';? ##設(shè)置通用日志文件輸出為表方式

set global log_output='File,TABLE';? ##設(shè)置通用日志文件輸出為文件和表方式

?(注意:上述命令只對(duì)當(dāng)前生效,當(dāng)MySQL重啟失效,如果要永久生效,需要配置my.cnf或者my.ini文件,見第5點(diǎn))

4、日志輸出效果圖:

(1)記錄到mysql.general_log表中的數(shù)據(jù)如下:

select * from mysql.general_log;

記錄到本地中的.log中的格式如下:

5、修改配置文件:

在my.cnf 或者my.ini 文件的 [mysqld]下的下方加入:

general_log=1? #為1表示開啟通用日志查詢,值為0表示關(guān)閉通用日志查詢

log_output=FILE,TABLE#設(shè)置通用日志的輸出格式為文件和表

?

?

二、慢查詢?nèi)罩?#xff1a;

MySQL的慢查詢?nèi)罩居脕碛涗浽贛ySQL中響應(yīng)時(shí)間超過閾值的語句,具體指運(yùn)行時(shí)間超過 long_query_time 值的SQL,則會(huì)被記錄到慢查詢?nèi)罩局?#xff08;日志可以寫入文件或者數(shù)據(jù)庫表,如果對(duì)性能要求高的話,建議寫文件)。默認(rèn)情況下,MySQL數(shù)據(jù)庫是不開啟慢查詢?nèi)罩镜?#xff0c;long_query_time的默認(rèn)值為10(即10秒,通常設(shè)置為1秒),即運(yùn)行10秒以上的語句是慢查詢語句。

一般來說,慢查詢發(fā)生在大表(比如:一個(gè)表的數(shù)據(jù)量有幾百萬),且查詢條件的字段沒有建立索引,此時(shí),要匹配查詢條件的字段會(huì)進(jìn)行全表掃描,耗時(shí)查過long_query_time,則為慢查詢語句。

默認(rèn)情況下,MySQL數(shù)據(jù)庫沒有開啟慢查詢?nèi)罩?#xff0c;需要我們手動(dòng)來設(shè)置這個(gè)參數(shù)。當(dāng)然,如果不是調(diào)優(yōu)需要的話,一般不建議啟動(dòng)該參數(shù),因?yàn)殚_啟慢查詢?nèi)罩緯?huì)或多或少帶來一定的性能影響。

1、查詢慢查詢?nèi)罩镜拈_啟情況:

show variables like '%quer%';

主要掌握以下的幾個(gè)參數(shù):

①slow_query_log?的值為ON為開啟慢查詢?nèi)罩?#xff0c;OFF則為關(guān)閉慢查詢?nèi)罩尽?/p>

②slow_query_log_file 的值是記錄的慢查詢?nèi)罩镜轿募新窂?#xff08;注意:默認(rèn)名為主機(jī)名.log,慢查詢?nèi)罩臼欠駥懭胫付ㄎ募?#xff0c;需要指定慢查詢的輸出日志格式為文件,相關(guān)命令為:show variables like ‘%log_output%’;去查看輸出的格式)。

③long_query_time 指定了慢查詢的閾值,即如果執(zhí)行語句的時(shí)間超過該閾值則為慢查詢語句,默認(rèn)值為10秒。

④log_queries_not_using_indexes 如果值設(shè)置為ON,則會(huì)記錄所有沒有利用索引的查詢(注意:如果只是將log_queries_not_using_indexes設(shè)置為ON,而將slow_query_log設(shè)置為OFF,此時(shí)該設(shè)置也不會(huì)生效,即該設(shè)置生效的前提是slow_query_log的值設(shè)置為ON),一般在性能調(diào)優(yōu)的時(shí)候會(huì)暫時(shí)開啟。

2、慢查詢相關(guān)配置(臨時(shí)):

如果都是通過MySQL的shell將參數(shù)設(shè)置進(jìn)去,重啟MySQL后,所有設(shè)置好的參數(shù)將失效,如果想要永久的生效,需要將配置參數(shù)寫入my.cnf文件中。

開啟慢查詢?nèi)罩驹O(shè)置:

set global slow_query_log='ON';?

set global slow_query_log='OFF';? ##關(guān)閉慢查詢?nèi)罩?

設(shè)置慢查詢?nèi)罩敬娣诺奈恢?#xff1a;

set global slow_query_log_file='/usr/local/mysql/data/slow.log';

設(shè)置超時(shí)記錄的閾值:

set long_query_time = 1;

3、慢查詢相關(guān)配置(永久):

在my.cnf 或者my.ini 文件的 [mysqld]下的下方加入以下配置,重啟MySQL服務(wù):

[mysqld]
slow_query_log = ON
slow_query_log_file = /usr/local/mysql/data/slow.log
long_query_time = 1

4、設(shè)置慢查詢存儲(chǔ)的方式(默認(rèn)是none):

set global log_output='File;? ##設(shè)置通用日志文件輸出為文件方式

set global log_output='TABLE';? ##設(shè)置通用日志文件輸出為表方式

set global log_output='File,TABLE';? ##設(shè)置通用日志文件輸出為文件和表方式

5、執(zhí)行測(cè)試sql語句:

select sleep(2);

6、慢查詢?nèi)罩居涗?#xff1a;

(1)慢查詢的日志記錄myql.slow_log表中,格式如下:

select * from mysql.slow_log;? ?

慢查詢的日志記錄到hostname.log文件中,格式如下:

可以看到,不管是表還是文件,都具體記錄了:是那條語句導(dǎo)致慢查詢(sql_text),該慢查詢語句的查詢時(shí)間(query_time),鎖表時(shí)間(Lock_time),以及掃描過的行數(shù)(rows_examined)等信息。

7、查詢當(dāng)前慢查的語句的個(gè)數(shù):

show global status like '%slow%';

?

三、使用慢查詢?nèi)罩痉治龉ぞ適ysqldumpslow分析日志:

我們通過查看慢查詢?nèi)罩究梢园l(fā)現(xiàn),很亂,數(shù)據(jù)量大的時(shí)候,可能一天會(huì)產(chǎn)生幾個(gè)G的日志,根本沒有辦法去清晰明了的分析。所以,這里,我們采用MySQL自帶的慢查詢?nèi)罩痉治龉ぞ呶鋈罩?mysqldumpslow工具進(jìn)行分析。

查看 mysqldumpslow 的幫助信息:mysqldumpslow --help

-s: 表示按何種方式排序:
  c: 訪問次數(shù)
  l: 鎖定時(shí)間
  r: 返回記錄
  t: 查詢時(shí)間
  al: 平均鎖定時(shí)間
  ar: 平均返回記錄數(shù)
  at: 平均查詢時(shí)間

-t: 返回前面多少條的數(shù)據(jù);

-g: 后邊搭配一個(gè)正則匹配模式,大小寫不敏感的。

得到返回記錄集最多的10個(gè)SQL:

mysqldumpslow -s r -t 10 /var/lib/mysql/show.log

得到訪問次數(shù)最多的10個(gè)SQL:

mysqldumpslow -s c -t 10 /var/lig/mysql/show.log

得到按照時(shí)間排序的前10條里面含有左連接的查詢語句:

mysqldumpslow -s t -t 10 -g "left join" /var/lig/mysql/show.log

另外建議在使用這些命令時(shí)結(jié)構(gòu) | 和more使用,否則有可能出現(xiàn)爆屏情況:

mysqldumpslow -s r -t 10 /var/lig/mysql/show.log | more

?

相關(guān)博客:

https://blog.csdn.net/timchen525/article/details/75268151

?

總結(jié)

以上是生活随笔為你收集整理的MySQL数据库:通用查询日志和慢查询日志分析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。