搜尋
首頁資料庫Redis淺談Redis中的字典、雜湊演算法和ReHash原理

這篇文章帶大家了解Redis中的字典、雜湊演算法和ReHash原理,希望對大家有幫助!

淺談Redis中的字典、雜湊演算法和ReHash原理

Redis 中的字典被廣泛用於實作Redis的各種功能,其中包括資料庫和雜湊鍵。

字典的底層實作為雜湊表,每個字典有兩個雜湊表,一個平常使用,另一個在進行rehash擴充空間時才使用。 【相關推薦:Redis影片教學

字典的結構定義

typedef struct dict {
	
	// 类型特定函数
	dictType *type;
	
	// 私有数据
	void *privdata;
	
	// 哈希表,两个元素
	dictht ht[2]
	
	// rehash时记录的索引下标,当没有rehash时,值为-1
	int rehashidx;

} dict;

==在進行rehash時,rehashidx每遷移一個索引的entry資料就會1;==

其中,哈希表dictht 的結構定義為:

typedef struct dictht {
	
	// 哈希表数组
	dictEntry **table;
	
	// 哈希表大小
	unsigned long size;
	
	// 哈希表大小掩码,用于计算索引值
	unsigned long sizenask;
	
	// 该哈希表已有节点的数量
	unsigned long uesd;

} dictht;

其中,table是數組,數組的每一個元素指向dictEntry 類型的指針, dictEntry 類型裡保存一個鍵值對。

在這裡也可以看出雜湊表的節點是鍊錶相連來解決雜湊衝突問題的,也就是鏈結位址法。

哈希衝突與哈希演算法

        為了實現從鍵到值的快速訪問,Redis使用了哈希表來保存所有鍵值對。 對應Redis設定的Key,而對應的並不是值本身,而是指向具體值的指標。使用雜湊表的最大好處就是可以用O(1)的時間複雜度快速找到鍵值對。但既然是哈希表,那麼必然會有哈希衝突的問題。

哈希衝突即指的是,當兩個key的雜湊值和雜湊桶計算對應關係時,剛好落在了同一個哈希桶上。

Redis解決哈希衝突的方式是使用鍊式哈希,即拉鍊法。當多個元素指向同一個雜湊桶時,在同一個雜湊桶中採用鍊錶來保存對應的數據,它們之間依序用指針連接。

雜湊演算法

當要將一個新的鍵值對加入字典裡面時,程式需要先根據鍵值對計算出雜湊值和索引值,然後再根據索引值,將包含新鍵值對的雜湊表節點放到雜湊表數組的指定索引上面。

reHash 過程

        在雜湊表中有個負載因子(load factor)來控制雜湊表所儲存的鍵值對數量。而這就需要rehash(重新散列)操作來完成。其中,負載因子的計算公式為:

// 负载因子 = 哈希表已保存的节点数量 / 哈希表大小
load_factor = ht[0].used / ht[0].size

哈希表擴展與收縮的條件如下:

  • 伺服器目前沒有在執行BGSAVE 指令或BGREWRITEAOF 指令,且雜湊表的負載因子大於等於1;
  • 伺服器目前正在執行BGSAVE 指令或BGREWRITEAOF 指令,且雜湊表的負載因子大於等於5;

上述的條件有一個滿足,就會執行rehash的過程。

如果伺服器正在執行BGSAVE  或BGREWRITEAOF時,Redis會建立目前伺服器程序的子程序

rehash的過程大概分成三步驟:

  • #給哈希表2分配更大的空間,例如是目前哈希表1的兩倍;

  • 把哈希表1中的資料重新映射並拷貝到哈希表2中;

  • 釋放哈希表1的空間;

其中,第一步分配空間的大小是由目前的rehash操作類型以及目前哈希表的鍵值對數量決定的。

  • 當執行的是擴展操作,分配的空間大小為第一個大於等於(哈希表的鍵值對數量* 2) 的2^n 值;

    假設目前的鍵值對數量為4,則4 * 2 = 8,因為8 剛好等於2^3,也就是剛好等於第一個等於2^n的值,所以擴充空間就為8;

  • 如果執行的是收縮操作,則分配的空間大小為第一個大於等於(哈希表的鍵值對數量) 的2^n 值;

######## ########漸進式reHash#########        當雜湊表數量多時,如果一下子將資料都複製過去,那麼就很有可能對伺服器造成影響。所以Redis是分多次進行rehash的,也就是漸進式rehash。 ######        簡單來說就是在第二步驟操作時,Redis仍然正常處理客戶端請求,每處理一個請求時,從哈希表1中的第一個索引位置開始,順從著將這個索引位置上所有的entries元素拷貝到哈希表2中;等下一次請求時,再順帶拷貝下一個索引位置的entries。 ######        這樣就很巧妙地將一次性大量拷貝的開銷,分攤到多次處理請求的過程中了,避免了耗時操作,保證了資料的快速存取。 ###

rehash時期間的雜湊表運算

        在進行 漸進式rehash運算時,字典的刪除、尋找、更新等運算會在兩個雜湊表中執行。例如要在字典中找一個鍵的話,會先去原表中查詢,如果找不到就會去新表查詢。

        而字典的新增作業一律只會儲存在新表中。

更多程式相關知識,請造訪:程式設計入門! !

以上是淺談Redis中的字典、雜湊演算法和ReHash原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:掘金社区。如有侵權,請聯絡admin@php.cn刪除
REDIS:探索其數據模型和結構REDIS:探索其數據模型和結構Apr 16, 2025 am 12:09 AM

Redis的數據模型和結構包括五種主要類型:1.字符串(String):用於存儲文本或二進制數據,支持原子操作。 2.列表(List):有序元素集合,適合隊列和堆棧。 3.集合(Set):無序唯一元素集合,支持集合運算。 4.有序集合(SortedSet):帶分數的唯一元素集合,適用於排行榜。 5.哈希表(Hash):鍵值對集合,適合存儲對象。

REDIS:對其數據庫方法進行分類REDIS:對其數據庫方法進行分類Apr 15, 2025 am 12:06 AM

Redis的數據庫方法包括內存數據庫和鍵值存儲。 1)Redis將數據存儲在內存中,讀寫速度快。 2)它使用鍵值對存儲數據,支持複雜數據結構,如列表、集合、哈希表和有序集合,適用於緩存和NoSQL數據庫。

為什麼要使用redis?利益和優勢為什麼要使用redis?利益和優勢Apr 14, 2025 am 12:07 AM

Redis是一個強大的數據庫解決方案,因為它提供了極速性能、豐富的數據結構、高可用性和擴展性、持久化能力以及廣泛的生態系統支持。 1)極速性能:Redis的數據存儲在內存中,讀寫速度極快,適合高並發和低延遲應用。 2)豐富的數據結構:支持多種數據類型,如列表、集合等,適用於多種場景。 3)高可用性和擴展性:支持主從復制和集群模式,實現高可用性和水平擴展。 4)持久化和數據安全:通過RDB和AOF兩種方式實現數據持久化,確保數據的完整性和可靠性。 5)廣泛的生態系統和社區支持:擁有龐大的生態系統和活躍社區,

了解NOSQL:Redis的關鍵特徵了解NOSQL:Redis的關鍵特徵Apr 13, 2025 am 12:17 AM

Redis的關鍵特性包括速度、靈活性和豐富的數據結構支持。 1)速度:Redis作為內存數據庫,讀寫操作幾乎瞬時,適用於緩存和會話管理。 2)靈活性:支持多種數據結構,如字符串、列表、集合等,適用於復雜數據處理。 3)數據結構支持:提供字符串、列表、集合、哈希表等,適合不同業務需求。

REDIS:確定其主要功能REDIS:確定其主要功能Apr 12, 2025 am 12:01 AM

Redis的核心功能是高性能的內存數據存儲和處理系統。 1)高速數據訪問:Redis將數據存儲在內存中,提供微秒級別的讀寫速度。 2)豐富的數據結構:支持字符串、列表、集合等,適應多種應用場景。 3)持久化:通過RDB和AOF方式將數據持久化到磁盤。 4)發布訂閱:可用於消息隊列或實時通信系統。

REDIS:流行數據結構指南REDIS:流行數據結構指南Apr 11, 2025 am 12:04 AM

Redis支持多種數據結構,具體包括:1.字符串(String),適合存儲單一值數據;2.列表(List),適用於隊列和棧;3.集合(Set),用於存儲不重複數據;4.有序集合(SortedSet),適用於排行榜和優先級隊列;5.哈希表(Hash),適合存儲對像或結構化數據。

redis計數器怎麼實現redis計數器怎麼實現Apr 10, 2025 pm 10:21 PM

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

redis命令行怎麼用redis命令行怎麼用Apr 10, 2025 pm 10:18 PM

使用 Redis 命令行工具 (redis-cli) 可通過以下步驟管理和操作 Redis:連接到服務器,指定地址和端口。使用命令名稱和參數向服務器發送命令。使用 HELP 命令查看特定命令的幫助信息。使用 QUIT 命令退出命令行工具。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境