欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一分鐘搞懂Redis的慢查詢?nèi)罩静僮?/h1>
 更新時間:2021年11月24日 15:32:05   作者:萬貓學社  
redis慢查詢指的是命令執(zhí)行時長比較長的查詢,本文詳細的介紹了慢查詢的具體操作,具有一定的參考價值,感興趣的可以了解一下

什么是慢查詢?

慢查詢,顧名思義就是比較慢的查詢,但是究竟是哪里慢呢?首先,我們了解一下Redis命令執(zhí)行的整個過程:

  • 發(fā)送命令
  • 命令排隊
  • 命令執(zhí)行
  • 返回結(jié)果

在慢查詢的定義中,統(tǒng)計比較慢的時間段指的是命令執(zhí)行這個步驟。沒有慢查詢,并不表示客戶端沒有超時問題,有可能網(wǎng)絡傳輸有延遲,也有可能排隊的命令比較多。

因為Redis中命令執(zhí)行的排隊機制,慢查詢會導致其他命令的級聯(lián)阻塞,所以當客戶端出現(xiàn)請求超時的時候,需要檢查該時間點是否有慢查詢,從而分析出由于慢查詢導致的命令級聯(lián)阻塞。

什么是慢查詢?nèi)罩荆?/h2>

慢查詢?nèi)罩臼荝edis服務端在命令執(zhí)行前后計算每條命令的執(zhí)行時長,當超過某個閾值是記錄下來的日志。日志中記錄了慢查詢發(fā)生的時間,還有執(zhí)行時長、具體什么命令等信息,它可以用來幫助開發(fā)和運維人員定位系統(tǒng)中存在的慢查詢。

如何獲取慢查詢?nèi)罩荆?/h2>

可以使用slowlog get命令獲取慢查詢?nèi)罩?,?code>slowlog get后面還可以加一個數(shù)字,用于指定獲取慢查詢?nèi)罩镜臈l數(shù),比如,獲取3條慢查詢?nèi)罩荆?/p>

> slowlog get 3
1) 1) (integer) 6107
   2) (integer) 1616398930
   3) (integer) 3109
   4) 1) "config"
      2) "rewrite"
2) 1) (integer) 6106
   2) (integer) 1613701788
   3) (integer) 36004
   4) 1) "flushall"
3) 1) (integer) 6105
   2) (integer) 1608722338
   3) (integer) 20449
   4) 1) "scan"
      2) "0"
      3) "MATCH"
      4) "*comment*"
      5) "COUNT"
      6) "10000"

從上面的例子中,可以看出每一條慢查詢?nèi)罩径加?個屬性組成:

  • 唯一標識ID
  • 命令執(zhí)行的時間戳
  • 命令執(zhí)行時長
  • 執(zhí)行的命名和參數(shù)

如何獲取慢查詢?nèi)罩镜拈L度?

可以使用slowlog len命令獲取慢查詢?nèi)罩镜拈L度,比如:

> slowlog len
(integer) 121

在上例中,當前Redis中有121條慢查詢?nèi)罩尽?/p>

如何清理慢查詢?nèi)罩荆?/h2>

可以使用slowlog reset命令清理慢查詢?nèi)罩?,比如?/p>

> slowlog len
(integer) 121
> slowlog reset
OK
> slowlog len
(integer) 0

怎么配置慢查詢的參數(shù)?

正如上面提到的,慢查詢需要如下兩個配置:

  • 命令執(zhí)行時長的指定閾值。
  • 存放慢查詢?nèi)罩镜臈l數(shù)。

Redis對應提供了兩個參數(shù):slowlog-log-slower-than和slowlog-max-len,接下來我們詳細介紹一下這兩個參數(shù)。

slowlog-log-slower-than

slowlog-log-slower-than的作用是指定命令執(zhí)行時長的閾值,執(zhí)行命令的時長超過這個閾值時就會被記錄下來。它的單位是微秒(1秒 = 1000毫秒 = 1000000微秒),默認是10000微秒。如果把slowlog-log-slower-than設置為0,將會記錄所有命令到日志中。如果把slowlog-log-slower-than設置小于0,將會不記錄任何命令到日志中。

在實際的生產(chǎn)環(huán)境中,需要根據(jù)Redis并發(fā)量來調(diào)整該配置。因為Redis采用單線程響應命令,如果命令執(zhí)行時間在1000微秒以上,那么Redis最多可支撐OPS不到1000,所以對于高并發(fā)場景的Redis建議設置為1000微秒。

slowlog-max-len

slowlog-max-len的作用是指定慢查詢?nèi)罩咀疃啻鎯Φ臈l數(shù)。實際上,Redis使用了一個列表存放慢查詢?nèi)罩?,slowlog-max-len就是這個列表的最大長度。當一個新的命令滿足滿足慢查詢條件時,被插入這個列表中。當慢查詢?nèi)罩玖斜硪呀?jīng)達到最大長度時,最早插入的那條命令將被從列表中移出。比如,slowlog-max-len被設置為10,當有第11條命令插入時,在列表中的第1條命令先被移出,然后再把第11條命令放入列表。

記錄慢查詢是Redis會對長命令進行截斷,不會大量占用大量內(nèi)存。在實際的生產(chǎn)環(huán)境中,為了減緩慢查詢被移出的可能和更方便地定位慢查詢,建議將慢查詢?nèi)罩镜拈L度調(diào)整的大一些。比如可以設置為1000以上。

如何進行配置

在Redis中有兩個修改配置的方法:

slowlog-log-slower-than 1000
slowlog-max-len 1200

修改Redis配置文件。比如,把slowlog-log-slower-than設置為1000,slowlog-max-len設置為1200:

使用config set命令動態(tài)修改。比如,還是把slowlog-log-slower-than設置為1000,slowlog-max-len設置為1200:

> config set slowlog-log-slower-than 1000
OK
> config set slowlog-max-len 1200
OK
> config rewrite
OK

如果要Redis把配置持久化到本地配置文件,需要執(zhí)行config rewrite命令。

總結(jié)

慢查詢指的是命令執(zhí)行時長比較長的查詢。通過slowlog get命令獲取慢查詢?nèi)罩荆煌ㄟ^slowlog len命令獲取慢查詢?nèi)罩镜拈L度;通過slowlog reset命令清理慢查詢?nèi)罩尽Mㄟ^slowlog-log-slower-than配置命令執(zhí)行時長的閾值;通過slowlog-max-len配置慢查詢?nèi)罩咀疃啻鎯Φ臈l數(shù)。

到此這篇關于一分鐘搞懂Redis的慢查詢?nèi)罩静僮鞯奈恼戮徒榻B到這了,更多相關Redis 慢查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

  • k8s部署redis集群實現(xiàn)過程實例詳解

    k8s部署redis集群實現(xiàn)過程實例詳解

    這篇文章主要為大家介紹了k8s部署redis集群實現(xiàn)過程實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • Redis 命令整理并說明如何使用

    Redis 命令整理并說明如何使用

    這篇文章主要介紹了Redis 命令整理并說明如何使用的相關資料,需要的朋友可以參考下
    2017-02-02
  • redis常用命令整理

    redis常用命令整理

    在本篇文章里小編給大家整理的是關于redis常用命令整理相關內(nèi)容需要的朋友們可以學習下。
    2020-03-03
  • Redis緩沖區(qū)溢出及解決方案分享

    Redis緩沖區(qū)溢出及解決方案分享

    Redis緩沖區(qū)溢出是指Redis緩沖區(qū)被寫入的數(shù)據(jù)超過了它的容量,導致數(shù)據(jù)無法存儲或被覆蓋。造成緩沖區(qū)溢出的原因可能是快速寫入大量數(shù)據(jù)、緩沖區(qū)未及時刷新或Redis服務器配置不當?shù)取?/div> 2023-04-04
  • 在redisCluster中模糊獲取key方式

    在redisCluster中模糊獲取key方式

    這篇文章主要介紹了在redisCluster中模糊獲取key方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • antd為Tree組件標題附加操作按鈕功能

    antd為Tree組件標題附加操作按鈕功能

    這篇文章主要介紹了antd為Tree組件標題附加操作按鈕功能,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • 啟動redis出現(xiàn)閃退情況的解決辦法

    啟動redis出現(xiàn)閃退情況的解決辦法

    最近使用Redis遇到啟動閃退的問題,查閱資料后在一位大神的文章中找到了答案,這篇文章主要給大家介紹了關于啟動redis出現(xiàn)閃退情況的解決辦法,需要的朋友可以參考下
    2023-11-11
  • Redis解決優(yōu)惠券秒殺應用案例

    Redis解決優(yōu)惠券秒殺應用案例

    這篇文章主要介紹了Redis解決優(yōu)惠券秒殺應用案例,本文先講了搶購問題,指出其中會出現(xiàn)的多線程問題,提出解決方案采用悲觀鎖和樂觀鎖兩種方式進行實現(xiàn),然后發(fā)現(xiàn)在搶購過程中容易出現(xiàn)一人多單現(xiàn)象,需要的朋友可以參考下
    2022-11-11
  • 最新評論