真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL慢日志查詢實例分析

本篇內(nèi)容介紹了“MySQL慢日志查詢實例分析”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)是一家專業(yè)提供康巴什企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站制作、成都做網(wǎng)站、H5響應(yīng)式網(wǎng)站、小程序制作等業(yè)務(wù)。10年已為康巴什眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計公司優(yōu)惠進行中。

MySQL慢日志查詢實例分析

一、慢查詢?nèi)罩靖拍?/h3>

對于SQL和索引的優(yōu)化問題,我們會使用explain去分析SQL語句。但是真正的企業(yè)級項目有成千上萬條SQL,我們不可能從頭開始一條一條explain去分析。我們從什么地方可以獲取那些運行時間長,耗性能的SQL??

我們可以打開慢查詢?nèi)罩?/strong>:

根據(jù)具體的業(yè)務(wù)和并發(fā)量來預(yù)估一個時間上限(20ms、100ms),設(shè)置好后開啟業(yè)務(wù),壓測后打開慢查詢?nèi)罩荆蜁吹匠^執(zhí)行時間的SQL,然后使用explain分析這些耗時的SQL語句

步驟如下:

  • 打開慢查詢?nèi)罩鹃_關(guān)slow_query_log

  • 設(shè)置合理的、業(yè)務(wù)可以接受的慢查詢時間上限

  • 壓測執(zhí)行各種業(yè)務(wù)

  • 查看慢查詢?nèi)罩?,找出所有?zhí)行耗時的SQL語句

  • 用explain分析這些耗時的SQL語句,從而針對性優(yōu)化

MySQL可以設(shè)置慢查詢?nèi)罩荆擲QL執(zhí)行的時間超過我們設(shè)定的時間,那么這些SQL就會被記錄在慢查詢?nèi)罩井斨?,然后我們通過查看日志,用explain分析這些SQL的執(zhí)行計劃,來判定為什么效率低下,是沒有使用到索引?還是索引本身創(chuàng)建的有問題?或者是索引使用到了,但是由于表的數(shù)據(jù)量太大,花費的時間就是很長,那么此時我們可以把表分成多個小表等。

慢查詢?nèi)罩鞠嚓P(guān)的參數(shù)如下所示:
(MySQL定義的很多的全局的開關(guān),都是在全局變量中存儲,可以用show/set variables查看或者設(shè)置全局變量的值)

MySQL慢日志查詢實例分析
慢查詢?nèi)罩鹃_關(guān)默認是關(guān)閉的
慢查詢?nèi)罩镜穆窂剑耗J在/var/lib/mysql/

慢查詢?nèi)罩居涗浟税袌?zhí)行時間超過參數(shù) long_query_time(單位:秒)所設(shè)置值的 SQL語句的日志,在MySQL上用命令可以查看,如下:

MySQL慢日志查詢實例分析
這個值是可以修改的:

MySQL慢日志查詢實例分析

二、慢查詢?nèi)罩緦嵺`

1. 打開慢查詢?nèi)罩鹃_關(guān)slow_query_log

MySQL慢日志查詢實例分析

在打開慢查詢?nèi)罩鹃_關(guān)的時候,報錯表示slow_query_log是一個global的變量(也有只影響當前session的變量,如:long_query_time 、profiling),修改后會影響所有的session,即影響所有正在訪問當前MySQL server的客戶端。
MySQL慢日志查詢實例分析

打開慢查詢?nèi)罩鹃_關(guān)成功!

2. 設(shè)置合理的、業(yè)務(wù)可以接受的慢查詢時間上限long_query_time

MySQL慢日志查詢實例分析
查看另一個session

MySQL慢日志查詢實例分析
發(fā)現(xiàn)還是默認的10s,故long_query_time只影響當前session

3. 壓測執(zhí)行各種業(yè)務(wù)

MySQL慢日志查詢實例分析
已經(jīng)超過我們設(shè)置的long_query_time=0.1s

4. 查看慢查詢?nèi)罩?/strong>

路徑:/var/lib/mysql/
MySQL慢日志查詢實例分析
MySQL慢日志查詢實例分析

5. 用explain分析這些耗時的SQL語句,從而針對性優(yōu)化

MySQL慢日志查詢實例分析
做了整表的搜索,把主鍵索引樹整個掃了一遍。

我們應(yīng)該給password添加索引,然后記得password是字符串格式,因為如果涉及類型轉(zhuǎn)換是用不了索引的

三、show profiles查看sql具體的運行時間

MySQL一般只顯示小數(shù)點后兩位的時間
MySQL慢日志查詢實例分析
打開profiling開關(guān),顯示更詳細的時間

MySQL慢日志查詢實例分析
沒有報錯,說明profiling變量只影響當前session

MySQL慢日志查詢實例分析

“MySQL慢日志查詢實例分析”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!


網(wǎng)頁標題:MySQL慢日志查詢實例分析
URL鏈接:http://weahome.cn/article/ggehco.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部