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

Redis?存儲對象信息用?Hash?和String的區(qū)別

 更新時間:2022年09月29日 09:16:46   作者:3A網絡_文文  
這篇文章主要介紹了Redis存儲對象信息用Hash和String的區(qū)別,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

前言

Redis 內部使用一個 RedisObject 對象來表示所有的 key 和 value,RedisObject 中的 type,則是代表一個 value 對象具體是何種數據類型,它包含字符串(String)、鏈表(List)、哈希結構(Hash)、集合(Set)、有序集合(Sorted set)。

日常工作中我們存儲對象信息的時候,一般有兩種做法,一種是用 Hash 存儲,另一種是 String 存儲。但好像并沒有所謂的最佳實踐,那么實際上到底用什么數據結構存儲更好呢?

首先簡單回顧下,Redis 的 Hash 和 String 結構。

String

String 數據結構是簡單的 key-value 類型,value 其實不僅是 String,也可以是數字。

Redis 中的 String 可以表示很多語義:

  • 字符串(bits)
  • 整數
  • 浮點數

這三種類型,Redis 會根據具體的場景完成自動轉換,并且根據需要選取底層的承載方式。String 在 Redis 內部存儲默認就是一個字符串,被 RedisObject 所引用,當遇到 incr、decr 等操作時會轉成數值型進行計算,此時 RedisObject 的 encoding 字段為 int。

在存儲過程中,我們可以將用戶信息使用 Json 序列化成字符串,然后將序列化后的字符串存入 Redis 進行緩存。

由于 Redis 的字符串是動態(tài)字符串,可以修改,內部結構類似于 Java 的 ArrayList,采用預分配冗余空間的方式來減少內存的頻繁分配。如上圖所示,內部為當前字符串實際分配的空間 capacity,一般高于實際字符串長度 len。

假設我們要存儲的結構是:

{
  "name": "xiaowang",
  "age": "35"
}

如果此時將此用戶信息的 name 改為 “xiaoli”,再存到 Redis 中,Redis 是不需要重新分配空間的。而且我們在讀取和存儲數據的時候只需要對做 Json 序列化與反序列化,比較方便。

Hash

Hash 在很多編程語言中都有著很廣泛的應用,而在 Redis 中也是如此。在 Redis 中,Hash 常常用來緩存一些對象信息,如用戶信息、商品信息、配置信息等,因此也被稱為字典(dictionary),Redis 的字典使用 Hash table 作為底層實現, 一個 Hash table 里面可以有多個哈希表節(jié)點,而每個哈希表節(jié)點保存了字典中的一個鍵值對。實際上,Redis 數據庫底層也是采用 Hash table 來存儲鍵值對的。

Redis 的 Hash 相當于 Java 的 HashMap,內部結構實現與 HashMap 一致,即數組 + 鏈表結構。只是 reHash 方式不一樣。

前面說到 String 適合存儲用戶信息,而 Hash 結構也可以存儲用戶信息,不過是對每個字段單獨存儲,因此可以在查詢時獲取部分字段的信息,節(jié)省網絡流量。

不過 Redis 的 Hash 的值只能是字符串,存儲上面的那個例子還好,如果存儲的用戶信息變?yōu)椋?/strong>

{
  "name": "xiaowang",
  "age": 25,
  "clothes": {
    "shirt": "gray",
    "pants": "read"
  }
}

那么該如何存儲 "clothes" 屬性又變成了該用 String 還是 Hash 的問題。

String 和 Hash 占用內存的比較

既然兩種數據結構都可以存儲結構體信息。到底哪種更加合適呢?

首先我們用代碼先插入 10000 條數據,然后用可視化工具來看看內存的占用情況。

const Redis = require("ioRedis");
const Redis0 = new Redis({port: 6370});
const Redis1 = new Redis({port: 6371});
const user = {
  name: 'name12345',
  age: 16,
  avatar: 'https://dss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=256767015,24101428&fm=26&gp=0.jpg',
  phone: '13111111111',
  email: '1111111@11.email',
  lastLogon: '2021-04-28 10:00:00',
}
async function main() {
  for (let i = 0; i < 10000; i++) {
    await Redis0.set(`String:user:${i}`, Json.Stringify(user));
    await Redis1.hmset(`Hash:user:${i}`, user);
  }
}
main().then(process.exit);

先看 Redis0:

再來看看 Redis1:

可以看到還是有點差距的,但是差距并不明顯。

網友討論

網上的用戶也有同樣的疑問, 因為值的長度是不確定的,所以不知道采用 String 還是 Hash 存儲更有效率。

這里我主要給大家翻譯下該問題下優(yōu)質的答案:

適合用 String 存儲的情況:

  • 每次需要訪問大量的字段
  • 存儲的結構具有多層嵌套的時候

適合用 Hash 存儲的情況:

  • 在大多數情況中只需要訪問少量字段
  • 自己始終知道哪些字段可用,防止使用 mget 時獲取不到想要的數據

總結

以上的環(huán)境博主都是部署在3A服務器上的,感興趣的朋友可以自己也部署一套。本文主要介紹了 Redis 存儲對象信息是用 Hash 還是 String,建議是大部分情況下使用 String 存儲就好,畢竟在存儲具有多層嵌套的對象時方便很多,占用的空間也比 Hash 小。當我們需要存儲一個特別大的對象時,而且在大多數情況中只需要訪問該對象少量的字段時,可以考慮使用 Hash。

到此這篇關于Redis 存儲對象信息用 Hash 和String的區(qū)別的文章就介紹到這了,更多相關Redis Hash與String內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Redis分布式鎖與Redlock算法實現

    Redis分布式鎖與Redlock算法實現

    在Redis中,可以使用多種方式實現分布式鎖,如使用SETNX命令或RedLock算法,本文就來介紹一下Redis分布式鎖與Redlock算法實現,感興趣的可以了解一下
    2023-12-12
  • 基于Redis延遲隊列的實現代碼

    基于Redis延遲隊列的實現代碼

    在生活中很多時候都會用到延遲隊列,本文基于Redis延遲隊列的實現代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Redis Template實現分布式鎖的實例代碼

    Redis Template實現分布式鎖的實例代碼

    使用Redis的SETNX命令獲取分布式鎖的步驟,接下來通過本文給大家介紹Redis Template實現分布式鎖的實例代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-09-09
  • Redis消息隊列的三種實現方式

    Redis消息隊列的三種實現方式

    本文主要介紹了Redis消息隊列的三種實現方式,主要包括List實現消息隊列,PubSub消息隊列,Stream消息隊列,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 詳解如何使用Redis實現分布式鎖

    詳解如何使用Redis實現分布式鎖

    Redis 作為一個獨立的三方系統(tǒng),其天生的優(yōu)勢就是可以作為一個分布式系統(tǒng)來使用,因此使用 Redis 實現的鎖都是分布式鎖,所以本文就給大家講講如何使用Redis實現分布式鎖,感興趣的小伙伴跟著小編來看看吧
    2023-08-08
  • Redis中pipeline(管道)的實現示例

    Redis中pipeline(管道)的實現示例

    Redis管道(Pipeline)技術是一種提高數據處理效率的機制,允許客戶端通過一次網絡往返(RTT)發(fā)送多個命令到服務端,并一次性接收所有響應,本文就來實現管道,感興趣的可以了解一下
    2024-10-10
  • Redis Value過大問題(鍵值過大)

    Redis Value過大問題(鍵值過大)

    這篇文章主要介紹了Redis Value過大問題(鍵值過大),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • dubbo服務使用redis注冊中心的系列異常解決

    dubbo服務使用redis注冊中心的系列異常解決

    這篇文章主要為大家介紹了dubbo服務在使用redis注冊中心遇到的一系列異常的解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-03-03
  • Redis分布式可重入鎖實現方案

    Redis分布式可重入鎖實現方案

    在單進程環(huán)境下,要保證一個代碼塊的同步執(zhí)行,直接用synchronized 關鍵字或ReetrantLock 即可,在分布式環(huán)境下,要保證多個節(jié)點的線程對代碼塊的同步訪問,就必須要用到分布式鎖方案,本文介紹一下基于 Redis實現的分布式鎖方案,感興趣的朋友一起看看吧
    2024-02-02
  • redis中如何做到內存優(yōu)化

    redis中如何做到內存優(yōu)化

    為了提高數據處理效率和降低存儲成本,優(yōu)化數據結構和采用高效的存儲策略至關重要,使用最小存儲形式、整數編碼、Redis的HyperLogLog等方法可以有效減少內存占用,Redis6引入的對象壓縮、設置合理的過期時間、數據分片
    2024-09-09

最新評論