亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL慢查詢優(yōu)化解決問(wèn)題

 更新時(shí)間:2022年03月16日 10:55:31   作者:@sonny-zhang  
這篇文章主要介紹了MySQL慢查詢優(yōu)化解決問(wèn)題,MySQL的慢查詢,全名是慢查詢?nèi)罩荆荕ySQL提供的一種日志記錄,用來(lái)記錄在MySQL中響應(yīng)時(shí)間超過(guò)閥值的語(yǔ)句,下文詳細(xì)介紹慢查詢的調(diào)優(yōu)情況,需要的小伙伴可以參考一下

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.log
  • slow-query-log-file:新版(5.6及以上版本)MySQL數(shù)據(jù)庫(kù)慢查詢?nèi)罩敬鎯?chǔ)路徑??梢圆辉O(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.log
  • long_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)文章

最新評(píng)論