MySQL慢查詢(xún)優(yōu)化解決問(wèn)題
1. MySQL慢查詢(xún)介紹
MySQL的慢查詢(xún)?nèi)罩臼荕ySQL提供的一種日志記錄,它用來(lái)記錄在MySQL中響應(yīng)時(shí)間超過(guò)閥值的語(yǔ)句,具體指運(yùn)行時(shí)間超過(guò)long_query_time值的SQL,則會(huì)被記錄到慢查詢(xún)?nèi)罩局小ong_query_time的默認(rèn)值為10,意思是運(yùn)行10S以上的語(yǔ)句。默認(rèn)情況下,Mysql數(shù)據(jù)庫(kù)并不啟動(dòng)慢查詢(xún)?nèi)罩?,需要我們手?dòng)來(lái)設(shè)置這個(gè)參數(shù),當(dāng)然,如果不是調(diào)優(yōu)需要的話,一般不建議啟動(dòng)該參數(shù),因?yàn)殚_(kāi)啟慢查詢(xún)?nèi)罩緯?huì)或多或少帶來(lái)一定的性能影響。慢查詢(xún)?nèi)罩局С謱⑷罩居涗泴?xiě)入文件,也支持將日志記錄寫(xiě)入數(shù)據(jù)庫(kù)表
慢查詢(xún)?nèi)罩鞠嚓P(guān)參數(shù):
MySQL 慢查詢(xún)的相關(guān)參數(shù)解釋?zhuān)?/strong>
slow_query_log
:是否開(kāi)啟慢查詢(xún)?nèi)罩荆?表示開(kāi)啟,0表示關(guān)閉。log-slow-queries
:舊版(5.6以下版本)MySQL數(shù)據(jù)庫(kù)慢查詢(xún)?nèi)罩敬鎯?chǔ)路徑??梢圆辉O(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.logslow-query-log-file
:新版(5.6及以上版本)MySQL數(shù)據(jù)庫(kù)慢查詢(xún)?nèi)罩敬鎯?chǔ)路徑??梢圆辉O(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.loglong_query_time
:慢查詢(xún)閾值,當(dāng)查詢(xún)時(shí)間多于設(shè)定的閾值時(shí),記錄日志。log_queries_not_using_indexes
:未使用索引的查詢(xún)也被記錄到慢查詢(xún)?nèi)罩局校蛇x項(xiàng))。log_output
:日志存儲(chǔ)方式。log_output='FILE'表示將日志存入文件,默認(rèn)值是'FILE'。log_output='TABLE'表示將日志存入數(shù)據(jù)庫(kù),這樣日志信息就會(huì)被寫(xiě)入到mysql.slow_log表中。MySQL數(shù)據(jù)庫(kù)支持同時(shí)兩種日志存儲(chǔ)方式,配置的時(shí)候以逗號(hào)隔開(kāi)即可,如:log_output='FILE,TABLE'。日志記錄到系統(tǒng)的專(zhuān)用日志表中,要比記錄到文件耗費(fèi)更多的系統(tǒng)資源,因此對(duì)于需要啟用慢查詢(xún)?nèi)罩?,又需要能夠獲得更高的系統(tǒng)性能,那么建議優(yōu)先記錄到文件。
2.發(fā)現(xiàn)問(wèn)題(主動(dòng)/被動(dòng))
問(wèn)題點(diǎn):數(shù)據(jù)庫(kù)查詢(xún)過(guò)程中速度過(guò)慢的SQL語(yǔ)句
主動(dòng):數(shù)據(jù)庫(kù)默認(rèn)情況下slow_query_log的值為OFF,表示慢查詢(xún)?nèi)罩臼墙玫?/p>
mysql> show variables ?like '%slow_query_log%'; +---------------------+-----------------------------------------------+ | Variable_name ? ? ? | Value ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? | +---------------------+-----------------------------------------------+ | slow_query_log ? ? ?| OFF ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? | | slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log | +---------------------+-----------------------------------------------+ 2 rows in set (0.00 sec) ? mysql> set global slow_query_log=1; Query OK, 0 rows affected (0.09 sec) ? mysql> show variables like '%slow_query_log%'; +---------------------+-----------------------------------------------+ | Variable_name ? ? ? | Value ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? | +---------------------+-----------------------------------------------+ | slow_query_log ? ? ?| ON ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?| | slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log | +---------------------+-----------------------------------------------+ 2 rows in set (0.00 sec)
被動(dòng):用戶(hù)在使用程序時(shí)候告知頁(yè)面反應(yīng)慢
3.找到原因-對(duì)癥下藥
原因點(diǎn):沒(méi)有加索引、索引失效、SQL極度復(fù)雜、高并發(fā)
1.表結(jié)構(gòu)設(shè)計(jì)時(shí)沒(méi)有索引導(dǎo)致
2.SQL語(yǔ)句導(dǎo)致索引失效
索引失效7字口訣:
- 模:模糊查詢(xún)LIKE以%開(kāi)頭
- 型:數(shù)據(jù)類(lèi)型錯(cuò)誤
- 數(shù):對(duì)索引字段使用內(nèi)部函數(shù)
- 空:索引列是NULL
- 運(yùn):索引列進(jìn)行四則運(yùn)算
- 最:復(fù)合索引不按索引列最左開(kāi)始查找
- 快:全表查找預(yù)計(jì)比索引更快
3.SQL極度復(fù)雜10張以上表聯(lián)合查詢(xún)
- 優(yōu)化表結(jié)構(gòu)和程序
4.高并發(fā)時(shí)段導(dǎo)致等待
- 在程序和數(shù)據(jù)庫(kù)之間加入緩存
Hole yor life get everything if you never give up.
到此這篇關(guān)于MySQL慢查詢(xún)優(yōu)化解決問(wèn)題的文章就介紹到這了,更多相關(guān)MySQL慢查詢(xún)優(yōu)化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql從5.7平滑升級(jí)到8.0.27的實(shí)現(xiàn)
mysql8.0已經(jīng)到了穩(wěn)定期,本文主要介紹了mysql從5.7平滑升級(jí)到8.0.27的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06MySQL主從復(fù)制搭建流程分步實(shí)現(xiàn)
這篇文章主要介紹了MySQL的主從復(fù)制原理詳細(xì)分析,讀寫(xiě)分離是基于主從復(fù)制來(lái)實(shí)現(xiàn)的。文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-11-11SQL創(chuàng)建視圖的注意事項(xiàng)及說(shuō)明
這篇文章主要介紹了SQL創(chuàng)建視圖的注意事項(xiàng)及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02MySQL 分區(qū)與分庫(kù)分表策略應(yīng)用小結(jié)
在大數(shù)據(jù)量、復(fù)雜查詢(xún)和高并發(fā)的應(yīng)用場(chǎng)景下,單一數(shù)據(jù)庫(kù)往往難以滿(mǎn)足性能和擴(kuò)展性的要求,本文將詳細(xì)介紹這兩種策略的基本概念、實(shí)現(xiàn)方法及優(yōu)缺點(diǎn),并通過(guò)實(shí)際案例展示如何在項(xiàng)目中應(yīng)用它們,感興趣的朋友一起看看吧2025-04-04MySQL數(shù)據(jù)庫(kù)之字符集?character
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)之字符集?character,文章基于MySQL的的相關(guān)資料展開(kāi)詳細(xì)介紹,具有一定的參考價(jià)值需要的小伙伴可以參考一下2022-05-05mysql 觸發(fā)器創(chuàng)建與使用方法示例
這篇文章主要介紹了mysql 觸發(fā)器創(chuàng)建與使用方法,結(jié)合實(shí)例形式分析了mysql 觸發(fā)器基本概念、原理、創(chuàng)建、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2020-05-05mysql關(guān)聯(lián)查詢(xún)速度慢的問(wèn)題及解決
這篇文章主要介紹了mysql關(guān)聯(lián)查詢(xún)速度慢的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03淺談sql語(yǔ)句中GROUP BY 和 HAVING的使用方法
GROUP BY語(yǔ)句和HAVING語(yǔ)句,經(jīng)過(guò)研究和練習(xí),終于明白如何使用了,在此記錄一下同時(shí)添加了一個(gè)自己舉的小例子,通過(guò)寫(xiě)這篇文章來(lái)加深下自己學(xué)習(xí)的效果,還能和大家分享下,同時(shí)也方便以后查閱,一舉多得,下面由小編來(lái)和大家一起學(xué)習(xí)2019-05-05