久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      詳細了解MySQL慢日志查詢

      本篇文章給大家?guī)砹岁P于mysql的相關知識,其中主要介紹了慢日志查詢的相關問題,還包括了show profiles查看sql具體的運行時間等相關內(nèi)容,希望對大家有幫助。

      詳細了解MySQL慢日志查詢

      推薦學習:mysql視頻教程

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

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

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

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

      步驟如下:

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

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

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

      • 查看慢查詢?nèi)罩荆页鏊袌?zhí)行耗時的SQL語句

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

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

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

      詳細了解MySQL慢日志查詢
      慢查詢?nèi)罩鹃_關默認是關閉的
      慢查詢?nèi)罩镜穆窂剑耗J在/var/lib/mysql/

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

      詳細了解MySQL慢日志查詢
      這個值是可以修改的:

      詳細了解MySQL慢日志查詢

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

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

      詳細了解MySQL慢日志查詢

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

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

      詳細了解MySQL慢日志查詢
      查看另一個session

      詳細了解MySQL慢日志查詢
      發(fā)現(xiàn)還是默認的10s,故long_query_time只影響當前session

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

      詳細了解MySQL慢日志查詢
      已經(jīng)超過我們設置的long_query_time=0.1s

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

      路徑:/var/lib/mysql/
      詳細了解MySQL慢日志查詢
      詳細了解MySQL慢日志查詢

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

      詳細了解MySQL慢日志查詢
      做了整表的搜索,把主鍵索引樹整個掃了一遍。

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

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

      MySQL一般只顯示小數(shù)點后兩位的時間
      詳細了解MySQL慢日志查詢
      打開profiling開關,顯示更詳細的時間

      詳細了解MySQL慢日志查詢
      沒有報錯,說明profiling變量只影響當前session

      詳細了解MySQL慢日志查詢

      推薦學習:mysql視頻教程

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號