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

Redis中大Key與熱Key的解決方案

 更新時間:2024年06月06日 09:05:26   作者:醉魚Java  
在工作中Redis已經(jīng)成為必備的一款高性能的緩存數(shù)據(jù)庫,但是在實際的使用過程中,我們常常會遇到兩個常見的問題,也就是文章標題所說的大 key與熱 key,本文給大家介紹了Redis中大Key與熱Key的解決方案,需要的朋友可以參考下

一、定義

1.1、什么是大key

  • 大 key 指的是一個鍵中包含了大量的數(shù)據(jù)。(總結(jié)一個字就是

    占用空間大key 通常指的是一個鍵包含了大量的數(shù)據(jù),使得該鍵對應值的占用的內(nèi)存超出了正常范圍。這個大小的閾值并不是固定的,而是相對于 Redis 實例的可用內(nèi)存而言。當一個鍵的大小超出了 Redis 實例可用內(nèi)存時,就可以認為它是一個大key。

    操作耗時:如果對一個 key 的操作所需的時間過長,導致性能下降或者影響其他請求的處理速度,也可以說這個 key 是 大key 。因為這種情況通常是由于該 key 下包含了大量的數(shù)據(jù)。

1.2、什么是熱key

  • 熱 key 指的是頻繁訪問的鍵。(總結(jié)就是,訪問頻繁。)

    頻繁訪問:在某一段時間內(nèi)被頻繁訪問的 key 就是 熱key

    業(yè)務方面:比如商城促銷的場景下,某個商品的緩存可能就會成為 熱key。這種情況下 熱key 反應的不僅是該鍵的訪問頻率高,還反映了用戶對某個業(yè)務功能的熱度。

    性能方面熱key 的頻繁訪問造成 Redis 的 CPU 占用率過高,造成響應時間延長或者請求阻塞,從而造成系統(tǒng)崩潰。

key 的大與不大,熱與不熱要根據(jù)自己的業(yè)務,從實際情況進行評估。

二、影響

2.1、大 key 的影響

  • 內(nèi)存消耗: 在進行緩存時降低緩存的效率,占用大量的內(nèi)存空間,使得 Redis 的內(nèi)存消耗急劇增加,還可能導致 Redis 實例的內(nèi)存資源不足,甚至出發(fā)內(nèi)存淘汰策略,從而影響系統(tǒng)的正常運行。
  • 性能下降:處理大的 key,會耗費更多的 CPU 時間以及帶寬,導致 Redis 性能下降。由于 Redis 還是單線程的,處理 大key 的操作進而會阻塞其他請求的處理,從而影響系統(tǒng)性能。
  • 持久化效率降低: 在進行持久化操作時,AOFRDB都會因為該 大key 耗費更多的時間,從而延遲持久化時間,分布式環(huán)境下甚至會造成緩存不一致。
  • 網(wǎng)絡傳輸延遲大key 在進行網(wǎng)絡傳輸時會增加網(wǎng)絡傳輸?shù)难舆t,在分布式環(huán)境下進行數(shù)據(jù)同步時可能會造成數(shù)據(jù)的不一致。

2.2、熱 key 的影響

  • CPU占用率高: 因為是 熱key,所以 CPU 一直占用,進而導致Redis實例的CPU負載增加。
  • 請求阻塞:如果 key 有訪問優(yōu)先級,熱key 的存在可能導致請求隊列中其他的請求被阻塞。
  • 響應時間延長:因為 熱key ,其他的請求被阻塞了造成響應時間延長。
  • 性能不均衡:流量訪問造成突刺,系統(tǒng)性能的不均衡。

2.3、小結(jié)

大key熱key 都會給 Redis 實例造成一系列的影響,如內(nèi)存占用過高,CPU 負載增加,持久化時間變長,性能下降等。

三、原因分析

3.1、大 key 產(chǎn)生的原因

產(chǎn)生 大key 的原因有很多種,下面咱就一起看一下工作中經(jīng)常遇到的這幾種。

3.1.1、存儲大量數(shù)據(jù)

存儲了大量數(shù)據(jù)也是我們經(jīng)常遇到 大key 的最多的原因了。

比如 String 類型直接保存了一個大的文本或者二進制數(shù)據(jù);Hash 結(jié)構(gòu)中存儲大量的鍵值對。

  • String
SET zuiyu_large_text_key "very large text content..."
  • Hash
HMSET zuiyu_large_hash_key field1 value1 field2 value2 ... fieldN valueN

3.1.2、緩存時間設置不合理

緩存時間設置不合理這個造成 大key 的原因大概是個隱藏挺深的老 bug,有的業(yè)務場景,使用 Redis 緩存數(shù)據(jù),業(yè)務是定時往該 key 上寫數(shù)據(jù),由于該 key 是沒有設置緩存時間的造成這個 key 隨著時間的流逝,占用的內(nèi)存越來越多,對于該點,只需要設置一個合理的過期時間即可。

前提是多次寫入不是覆蓋,而是追加才會有該問題。

SETEX zuiyu_key_with_expiry value 3600  # 設置過期時間為3600秒

3.1.3、數(shù)據(jù)結(jié)構(gòu)使用不當

在使用 List 數(shù)據(jù)結(jié)構(gòu)存儲數(shù)據(jù)時,重復的添加數(shù)據(jù),造成該 key 越來越大,實際上業(yè)務是不需要有重復的數(shù)據(jù)存在的。

  • List
LPUSH zuiyu_large_list_key value

3.1.4、小結(jié)

大key 的產(chǎn)生根本原因就是在一個 key 下面存儲的數(shù)據(jù)多了。

3.2、熱 key 產(chǎn)生的原因

3.2.1、熱門數(shù)據(jù)

熱key 的產(chǎn)生一般意味著系統(tǒng)訪問火爆了,但是火爆的只是其中一個點或者n個點。類似微博中某個明星的瓜,當上頭條的時候,大量的人去訪問,造成了該明星所對應的 key 成為 熱key。

3.2.2、頻繁的更新

某些業(yè)務場景,單位時間內(nèi)一直頻繁的對 key 進行更新,該 key 也會成為 熱key。

3.2.3、熱門搜索

類似于第一中的熱門數(shù)據(jù),產(chǎn)生了熱門數(shù)據(jù),該數(shù)據(jù)對應的熱門關(guān)鍵詞也被大量的用戶去搜索,造成該關(guān)鍵詞被頻繁訪問,最終導致該 key 也稱為 熱key。

3.2.4、小結(jié)

熱key 的產(chǎn)生無外乎熱門數(shù)據(jù),熱門數(shù)據(jù)產(chǎn)生的熱門關(guān)鍵詞以及對同一個 key 在某段時間內(nèi)的頻繁訪問。

四、解決方案

4.1、大key的解決方案

  • 合理的數(shù)據(jù)結(jié)構(gòu)
  • 合理的緩存時間
  • 大key 進行拆分為多個 小key
  • 定期對 大key 進行清理

4.2、熱key的解決方案

  • 合理的緩存淘汰策略
  • 熱點數(shù)據(jù)分片

將熱點數(shù)據(jù)分散到不同的Redis實例,提升系統(tǒng)的吞吐量。

  • 緩存預熱

在系統(tǒng)啟動或者活動高峰開啟之前進行緩存預熱,提前將需要的數(shù)據(jù)加載到緩存,減少熱點數(shù)據(jù)首次訪問的時間。

  • 隨機緩存失效時間

避免大量的key同一時間批量失效,造成緩存雪崩與緩存穿透。

  • 緩存穿透

使用布隆過濾器進行緩存請求過濾,防止無效請求進入到緩存層。

五、總結(jié)

針對 大key 我們要盡可能的避免同一個 key 下大量的數(shù)據(jù)。 針對 熱key 我們要合理設置過期時間,增加布隆過濾器等技術(shù)實現(xiàn)無效請求過濾,對即將到來的數(shù)據(jù)進行緩存預熱、熱點數(shù)據(jù)分片處理。

以上就是Redis中大Key與熱Key的解決方案的詳細內(nèi)容,更多關(guān)于Redis大Key與熱Key的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • redis 查看所有的key方式

    redis 查看所有的key方式

    這篇文章主要介紹了redis 查看所有的key方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • Redis Stat的安裝指南

    Redis Stat的安裝指南

    這篇文章主要介紹了Redis Stat的安裝指南的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • 淺談一下Redis的緩存穿透、擊穿和雪崩

    淺談一下Redis的緩存穿透、擊穿和雪崩

    這篇文章主要介紹了淺談一下Redis緩存穿透、擊穿和雪崩,緩存穿透是指在使用緩存系統(tǒng)時,頻繁查詢一個不存在于緩存中的數(shù)據(jù),導致這個查詢每次都要通過緩存層去查詢數(shù)據(jù)源,無法從緩存中獲得結(jié)果,需要的朋友可以參考下
    2023-08-08
  • redis基本類型和使用方法詳解

    redis基本類型和使用方法詳解

    這篇文章主要介紹了redis基本類型和使用方法詳解,需要的朋友可以參考下
    2020-02-02
  • Redis性能大幅提升之Batch批量讀寫詳解

    Redis性能大幅提升之Batch批量讀寫詳解

    這篇文章主要給大家介紹了關(guān)于Redis性能大幅提升之Batch批量讀寫的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來跟著小編一起來學習學習吧。
    2017-06-06
  • 詳解Redis SCAN命令實現(xiàn)有限保證的原理

    詳解Redis SCAN命令實現(xiàn)有限保證的原理

    這篇文章主要介紹了Redis SCAN命令實現(xiàn)有限保證的原理,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-07-07
  • 淺談Redis緩存更新策略

    淺談Redis緩存更新策略

    這篇文章主要介紹了Redis緩存更新策略的相關(guān)資料,講解的十分細致,有需要的小伙伴可以參考下
    2022-08-08
  • SpringBoot集成Redis的思路詳解

    SpringBoot集成Redis的思路詳解

    Redis是一個開源的使用ANSI C語言編寫、支持網(wǎng)絡、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫,并提供多種語言的API。接下來通過本文給大家分享SpringBoot集成Redis的詳細過程,感興趣的朋友一起看看吧
    2021-10-10
  • Redis?key的過期時間和永久有效的實現(xiàn)

    Redis?key的過期時間和永久有效的實現(xiàn)

    在Redis中,鍵可以設置過期時間或被永久保存,`EXPIRE`和`PEXPIRE`命令分別用于設置鍵的過期時間,具有一定的參考價值,感興趣的可以了解一下
    2024-09-09
  • 詳解RedisTemplate下Redis分布式鎖引發(fā)的系列問題

    詳解RedisTemplate下Redis分布式鎖引發(fā)的系列問題

    這篇文章主要介紹了詳解RedisTemplate下Redis分布式鎖引發(fā)的系列問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03

最新評論