首頁(yè)常見(jiàn)問(wèn)題正文

MySQL怎樣開(kāi)啟慢查詢?nèi)罩荆?/h1>

更新時(shí)間:2023-08-07 來(lái)源:黑馬程序員 瀏覽量:

IT培訓(xùn)班

慢查詢?nèi)罩居涗浟怂袌?zhí)行時(shí)間超過(guò)指定參數(shù)(long_query_time,單位:秒,默認(rèn)10秒)的所有SQL語(yǔ)句的日志。MySQL的慢查詢?nèi)罩灸J(rèn)沒(méi)有開(kāi)啟,我們可以查看一下系統(tǒng)變量 slow_query_log。
查看系統(tǒng)變量

如果要開(kāi)啟慢查詢?nèi)罩?,需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息:

#開(kāi)啟MySQL慢日志查詢開(kāi)關(guān)
slow_query_log=1
#設(shè)置慢日志的時(shí)間為2秒,SQL語(yǔ)句執(zhí)行時(shí)間超過(guò)2秒,就會(huì)視為慢查詢,記錄慢查詢?nèi)罩?
long_query_time=2

配置完畢之后,通過(guò)以下指令重新啟動(dòng)MySQL服務(wù)器進(jìn)行測(cè)試,查看慢日志文件中記錄的信息,/var/lib/mysql/localhost-slow.log。

systemctlrestartmysqld

然后,再次查看開(kāi)關(guān)情況,慢查詢?nèi)罩揪鸵呀?jīng)打開(kāi)了。

打開(kāi)慢查詢?nèi)罩? width=

測(cè)試:

A. 執(zhí)行如下SQL語(yǔ)句:

select*fromtb_user;--這條SQL執(zhí)行效率比較高,執(zhí)行耗時(shí)0.00sec 
selectcount(*)fromtb_sku;--由于tb_sku表中,預(yù)先存入了1000w的記錄,count一次,耗時(shí)
13.35sec

B. 檢查慢查詢?nèi)罩荆?/p>

最終我們發(fā)現(xiàn),在慢查詢?nèi)罩局?,只?huì)記錄執(zhí)行時(shí)間超多我們預(yù)設(shè)時(shí)間(2s)的SQL,執(zhí)行較快的SQL是不會(huì)記錄的。

1691404372187_圖片3.png

那這樣,通過(guò)慢查詢?nèi)罩?,就可以定位出?zhí)行效率比較低的SQL,從而有針對(duì)性的進(jìn)行優(yōu)化。


分享到:

在線咨詢 我要報(bào)名
和我們?cè)诰€交談!