MySQL慢查詢優(yōu)化解決問(wèn)題
1. MySQL慢查詢介紹
MySQL的慢查詢?nèi)罩臼荕ySQL提供的一種日志記錄,它用來(lái)記錄在MySQL中響應(yīng)時(shí)間超過(guò)閥值的語(yǔ)句,具體指運(yùn)行時(shí)間超過(guò)long_query_time值的SQL,則會(huì)被記錄到慢查詢?nèi)罩局?。long_query_time的默認(rèn)值為10,意思是運(yùn)行10S以上的語(yǔ)句。默認(rèn)情況下,Mysql數(shù)據(jù)庫(kù)并不啟動(dòng)慢查詢?nèi)罩?,需要我們手?dòng)來(lái)設(shè)置這個(gè)參數(shù),當(dāng)然,如果不是調(diào)優(yōu)需要的話,一般不建議啟動(dòng)該參數(shù),因?yàn)殚_(kāi)啟慢查詢?nèi)罩緯?huì)或多或少帶來(lái)一定的性能影響。慢查詢?nèi)罩局С謱⑷罩居涗泴?xiě)入文件,也支持將日志記錄寫(xiě)入數(shù)據(jù)庫(kù)表
慢查詢?nèi)罩鞠嚓P(guān)參數(shù):
MySQL 慢查詢的相關(guān)參數(shù)解釋:
slow_query_log
:是否開(kāi)啟慢查詢?nèi)罩荆?表示開(kāi)啟,0表示關(guān)閉。log-slow-queries
:舊版(5.6以下版本)MySQL數(shù)據(jù)庫(kù)慢查詢?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ù)慢查詢?nèi)罩敬鎯?chǔ)路徑??梢圆辉O(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.loglong_query_time
:慢查詢閾值,當(dāng)查詢時(shí)間多于設(shè)定的閾值時(shí),記錄日志。log_queries_not_using_indexes
:未使用索引的查詢也被記錄到慢查詢?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)的專用日志表中,要比記錄到文件耗費(fèi)更多的系統(tǒng)資源,因此對(duì)于需要啟用慢查詢?nèi)罩?,又需要能夠獲得更高的系統(tǒng)性能,那么建議優(yōu)先記錄到文件。
2.發(fā)現(xiàn)問(wèn)題(主動(dòng)/被動(dòng))
問(wèn)題點(diǎn):數(shù)據(jù)庫(kù)查詢過(guò)程中速度過(guò)慢的SQL語(yǔ)句
主動(dòng):數(shù)據(jù)庫(kù)默認(rèn)情況下slow_query_log的值為OFF,表示慢查詢?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):用戶在使用程序時(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字口訣:
- 模:模糊查詢LIKE以%開(kāi)頭
- 型:數(shù)據(jù)類型錯(cuò)誤
- 數(shù):對(duì)索引字段使用內(nèi)部函數(shù)
- 空:索引列是NULL
- 運(yùn):索引列進(jìn)行四則運(yùn)算
- 最:復(fù)合索引不按索引列最左開(kāi)始查找
- 快:全表查找預(yù)計(jì)比索引更快
3.SQL極度復(fù)雜10張以上表聯(liá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慢查詢優(yōu)化解決問(wèn)題的文章就介紹到這了,更多相關(guān)MySQL慢查詢優(yōu)化內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql 加了 skip-name-resolve不能鏈接數(shù)據(jù)庫(kù)問(wèn)題的解決方法
這篇文章主要介紹了mysql 加了 skip-name-resolve不能鏈接數(shù)據(jù)庫(kù)問(wèn)題的解決方法,需要的朋友可以參考下2016-04-04在MySQL中用正則表達(dá)式替換數(shù)據(jù)庫(kù)中的內(nèi)容的方法
在MySQL中用正則表達(dá)式替換數(shù)據(jù)庫(kù)中的內(nèi)容的方法...2007-03-03深入理解MySQL雙字段分區(qū)(OVER(PARTITION BY A,B)
本文主要介紹了MySQL中的窗口函數(shù)雙字段分區(qū)功能(OVER(PARTITION BY A,B),分析其在數(shù)據(jù)分組和性能優(yōu)化中的應(yīng)用,提高查詢效率,具有一定的參考價(jià)值,感興趣的可以了解一下2024-09-09mybatis實(shí)戰(zhàn)之?dāng)r截器解讀
這篇文章主要介紹了mybatis實(shí)戰(zhàn)之?dāng)r截器解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03關(guān)于mysql數(shù)據(jù)庫(kù)誤刪除后的數(shù)據(jù)恢復(fù)操作說(shuō)明
下面小編就為大家?guī)?lái)一篇關(guān)于mysql數(shù)據(jù)庫(kù)誤刪除后的數(shù)據(jù)恢復(fù)操作說(shuō)明。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03mysql?blocked?because?of?many?connection?errors解決記錄
這篇文章主要為大家介紹了mysql?blocked?because?of?many?connection?errors解決方法記錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10