發表於2025-01-23
Redis設計與實現 pdf epub mobi txt 電子書 下載
《Redis設計與實現》對Redis的大多數單機功能以及所有多機功能的實現原理進行瞭介紹,展示瞭這些功能的核心數據結構以及關鍵的算法思想。通過閱讀本書,讀者可以快速、有效地瞭解Redis的內部構造以及運作機製,這些知識可以幫助讀者更好、更高效地使用Redis。本書主要分為四大部分。第一部分“數據結構與對象”介紹瞭Redis中的各種對象及其數據結構,並說明這些數據結構如何影響對象的功能和性能。第二部分“單機數據庫的實現”對Redis實現單機數據庫的方法進行瞭介紹,包括數據庫、RDB持久化、AOF持久化、事件等。第三部分“多機數據庫的實現”對Redis的Sentinel、復製(replication)、集群(cluster)三個多機功能進行瞭介紹。第四部分“獨立功能的實現”對Redis中各個相對獨立的功能模塊進行瞭介紹,涉及發布與訂閱、事務、Lua腳本、排序、二進製位數組、慢查詢日誌、監視器等。
黃健宏,軟件開發者,他喜歡函數式編程,熱愛開源軟件。齣於對數據庫的強烈興趣,他開始閱讀和分析 Redis 源代碼,並對 Redis 2.6 和 Redis 3.0 的源代碼進行瞭詳細注釋。他翻譯並維護著 Redis 中文文檔網站 www.RedisDoc.com ,編寫瞭 OORedis 庫。除此之外,他還是《Redis in Action》一書的譯者。
前言
緻謝
第1章 引言 1
1.1 Redis版本說明 1
1.2 章節編排 1
1.3 推薦的閱讀方法 4
1.4 行文規則 4
1.5 配套網站 5
第一部分·數據結構與對象
第2章 簡單動態字符串 8
2.1 SDS的定義 9
2.2 SDS與C字符串的區彆 10
2.3 SDS API 17
2.4 重點迴顧 18
2.5 參考資料 18
第3章 鏈錶 19
3.1 鏈錶和鏈錶節點的實現 20
3.2 鏈錶和鏈錶節點的API 21
3.3 重點迴顧 22
第4章 字典 23
4.1 字典的實現 24
4.2 哈希算法 27
4.3 解決鍵衝突 28
4.4 rehash 29
4.5 漸進式rehash 32
4.6 字典API 36
4.7 重點迴顧 37
第5章 跳躍錶 38
5.1 跳躍錶的實現 39
5.2 跳躍錶API 44
5.3 重點迴顧 45
第6章 整數集閤 46
6.1 整數集閤的實現 46
6.2 升級 48
6.3 升級的好處 50
6.4 降級 51
6.5 整數集閤API 51
6.6 重點迴顧 51
第7章 壓縮列錶 52
7.1 壓縮列錶的構成 52
7.2 壓縮列錶節點的構成 54
7.3 連鎖更新 57
7.4 壓縮列錶API 59
7.5 重點迴顧 59
第8章 對象 60
8.1 對象的類型與編碼 60
8.2 字符串對象 64
8.3 列錶對象 68
8.4 哈希對象 71
8.5 集閤對象 75
8.6 有序集閤對象 77
8.7 類型檢查與命令多態 81
8.8 內存迴收 84
8.9 對象共享 85
8.10 對象的空轉時長 87
8.11 重點迴顧 88
第二部分·單機數據庫的實現
第9章 數據庫 90
9.1 服務器中的數據庫 90
9.2 切換數據庫 91
9.3 數據庫鍵空間 93
9.4 設置鍵的生存時間或過期時間 99
9.5 過期鍵刪除策略 107
9.6 Redis的過期鍵刪除策略 108
9.7 AOF、RDB和復製功能對過期鍵的處理 111
9.8 數據庫通知 113
9.9 重點迴顧 117
第10章 RDB持久化 118
10.1 RDB 文件的創建與載入 119
10.2 自動間隔性保存 121
10.3 RDB 文件結構 125
10.4 分析RDB文件 133
10.5 重點迴顧 137
10.6 參考資料 137
第11章 AOF持久化 138
11.1 AOF持久化的實現 139
11.2 AOF文件的載入與數據還原 142
11.3 AOF重寫 143
11.4 重點迴顧 150
第12章 事件 151
12.1 文件事件 151
12.2 時間事件 156
12.3 事件的調度與執行 159
12.4 重點迴顧 161
12.5 參考資料 161
第13章 客戶端 162
13.1 客戶端屬性 163
13.2 客戶端的創建與關閉 172
13.3 重點迴顧 174
第14章 服務器 176
14.1 命令請求的執行過程 176
14.2 serverCron函數 184
14.3 初始化服務器 192
14.4 重點迴顧 196
第三部分·多機數據庫的實現
第15章 復製 198
15.1 舊版復製功能的實現 199
15.2 舊版復製功能的缺陷 201
15.3 新版復製功能的實現 203
15.4 部分重同步的實現 204
15.5 PSYNC 命令的實現 209
15.6 復製的實現 211
15.7 心跳檢測 216
15.8 重點迴顧 218
第16章 Sentinel 219
16.1 啓動並初始化Sentinel 220
16.2 獲取主服務器信息 227
16.3 獲取從服務器信息 229
16.4 嚮主服務器和從服務器發送信息 230
16.5 接收來自主服務器和從服務器的頻道信息 231
16.6 檢測主觀下綫狀態 234
16.7 檢查客觀下綫狀態 236
16.8 選舉領頭Sentinel 238
16.9 故障轉移 240
16.10 重點迴顧 243
16.11 參考資料 244
第17章 集群 245
17.1 節點 245
17.2 槽指派 251
17.3 在集群中執行命令 258
17.4 重新分片 265
17.5 ASK錯誤 267
17.6 復製與故障轉移 273
17.7 消息 281
17.8 重點迴顧 288
第四部分·獨立功能的實現
第18章 發布與訂閱 290
18.1 頻道的訂閱與退訂 292
18.2 模式的訂閱與退訂 295
18.3 發送消息 298
18.4 查看訂閱信息 300
18.5 重點迴顧 303
18.6 參考資料 304
第19章 事務 305
19.1 事務的實現 306
19.2 WATCH 命令的實現 310
19.3 事務的ACID 性質 314
19.4 重點迴顧 319
19.5 參考資料 320
第20章 Lua腳本 321
20.1 創建並修改Lua 環境 322
20.2 Lua 環境協作組件 327
20.3 EVAL命令的實現 329
20.4 EVALSHA 命令的實現 332
20.5 腳本管理命令的實現 333
20.6 腳本復製 336
20.7 重點迴顧 342
20.8 參考資料 343
第21章 排序 344
21.1 SORT 命令的實現 345
21.2 ALPHA 選項的實現 347
21.3 ASC 選項和DESC 選項的實現 348
21.4 BY選項的實現 350
21.5 帶有ALPHA 選項的BY 選項的實現 352
21.6 LIMIT 選項的實現 353
21.7 GET選項的實現 355
21.8 STORE 選項的實現 358
21.9 多個選項的執行順序 359
21.10 重點迴顧 361
第22章 二進製位數組 362
22.1 位數組的錶示 363
22.2 GETBIT命令的實現 365
22.3 SETBIT 命令的實現 366
22.4 BITCOUNT 命令的實現 369
22.5 BITOP 命令的實現 376
22.6 重點迴顧 377
22.7 參考資料 377
第23章 慢查詢日誌 378
23.1 慢查詢記錄的保存 380
23.2 慢查詢日誌的閱覽和刪除 382
23.3 添加新日誌 383
23.4 重點迴顧 385
第24章 監視器 386
24.1 成為監視器 387
24.2 嚮監視器發送命令信息 387
24.3 重點迴顧 388
時間迴到2011年4月,當時我正在編寫一個用戶關係模塊,這個模塊需要實現一個“共同關注”功能,用於計算齣兩個用戶關注瞭哪些相同的用戶。
舉個例子,假設huangz關注瞭peter、tom、jack三個用戶,而john關注瞭peter、tom、bob、david四個用戶,那麼當huangz訪問john的頁麵時,共同關注功能就會計算並打印齣類似“你跟john都關注瞭peter和tom”這樣的信息。
從集閤計算的角度來看,共同關注功能本質上就是計算兩個用戶關注集閤的交集,因為交集這個概念是如此的常見,所以我很自然地認為共同關注這個功能可以很容易地實現,但現實卻給瞭我當頭一棒:我所使用的關係數據庫並不直接支持交集計算操作,要計算兩個集閤的交集,除瞭需要對兩個數據錶執行閤並(join)操作之外,還需要對閤並的結果執行去重復(distinct)操作,最終導緻交集操作的實現變得異常復雜。
是否存在直接支持集閤操作的數據庫呢?帶著這個疑問,我在搜索引擎上麵進行查找,並最終發現瞭Redis。在我看來,Redis正是我想要找的那種數據庫——它內置瞭集閤數據類型,並支持對集閤執行交集、並集、差集等集閤計算操作,其中的交集計算操作可以直接用於實現我想要的共同關注功能。
得益於Redis本身的簡單性,以及Redis手冊的詳盡和完善,我很快學會瞭怎樣使用Redis的集閤數據類型,並用它重新實現瞭整個用戶關係模塊:重寫之後的關係模塊不僅代碼量更少,速度更快,更重要的是,之前需要使用一段甚至一大段SQL查詢纔能實現的功能,現在隻需要調用一兩個Redis命令就能夠實現瞭,整個模塊的可讀性得到瞭極大的提高。
自此之後,我開始在越來越多的項目裏麵使用Redis,與此同時,我對Redis的內部實現也越來越感興趣,一些問題開始頻繁地齣現在我的腦海中,比如:
??Redis的五種數據類型分彆是由什麼數據結構實現的?
??Redis的字符串數據類型既可以存儲字符串(比如"hello world"),又可以存儲整數和浮點數(比如10086和3.14),甚至是二進製位(使用SETBIT等命令),Redis在內部是怎樣存儲這些值的?
??Redis的一部分命令隻能對特定數據類型執行(比如APPEND隻能對字符串執行,HSET隻能對哈希錶執行),而另一部分命令卻可以對所有數據類型執行(比如DEL、TYPE和EXPIRE),不同的命令在執行時是如何進行類型檢查的?Redis在內部是否實現瞭一個類型係統?
??Redis的數據庫是怎樣存儲各種不同數據類型的鍵值對的?數據庫裏麵的過期鍵又是怎樣實現自動刪除的?
??除瞭數據庫之外,Redis還擁有發布與訂閱、腳本、事務等特性,這些特性又是如何實現的?
??Redis使用什麼模型或者模式來處理客戶端的命令請求?一條命令請求從發送到返迴需要經過什麼步驟?
為瞭找到這些問題的答案,我再次在搜索引擎上麵進行查找,可惜的是這次搜索並沒有多少收獲:Redis還是一個非常年輕的軟件,對它的最好介紹就是官方網站上麵的文檔,但是這些文檔主要關注的是怎樣使用Redis,而不是介紹Redis的內部實現。另外,網上雖然有一些博客文章對Redis的內部實現進行瞭介紹,但這些文章要麼不齊全(隻介紹瞭Redis中的少數幾個特性),要麼就寫得過於簡單(隻是一些概述性的文章),要麼關注的就是舊版本(比如2.0、2.2或者2.4,而當時的最新版已經是2.6瞭)。
綜閤來看,詳細而且完整地介紹Redis內部實現的資料,無論是外文還是中文都不存在。意識到這一點之後,我決定自己動手注釋Redis的源代碼,從中尋找問題的答案,並通過寫博客的方式與其他Redis用戶分享我的發現。在積纍瞭七八篇Redis源代碼注釋文章之後,我想如果能將這些博文匯集成書的話,那一定會非常有趣,並且我自己也會從中學到很多知識。於是我在2012年年末開始創作《Redis設計與實現》,並最終於2013年3月8日在互聯網發布瞭本書的第一版。
盡管《Redis設計與實現》第一版順利發布瞭,但在我的心目中,這個第一版還是有很多不完善的地方:
??比如說,因為第一版是我邊注釋Redis源代碼邊寫的,如果有足夠時間讓我先完整地注釋一遍Redis的源代碼,然後再進行寫作的話,那麼書本在內容方麵應該會更為全麵。
??又比如說,第一版隻介紹瞭Redis的內部機製和單機特性,但並沒有介紹Redis多機特性,而我認為隻有將關於多機特性的介紹也包含進來,這本《Redis設計與實現》纔算是真正的完成瞭。
就在我考慮應該何時編寫新版來修復這些缺陷的時候,機械工業齣版社的吳怡編輯來信詢問我是否有興趣正式地齣版《Redis設計與實現》,能夠正式地齣版自己寫的書一直是我夢寐以求的事情,我找不到任何拒絕這一邀請的理由,就這樣,在《Redis設計與實現》第一版發布幾天之後,新版《Redis設計與實現》的寫作也馬不停蹄地開始瞭。
從2013年3月到2014年1月這11個月間,我重新注釋瞭Redis在unstable分支的源代碼(也即是現在的Redis 3.0源代碼),重寫瞭《Redis設計與實現》第一版已有的所有章節,並嚮書中添加瞭關於二進製位操作(bitop)、排序、復製、Sentinel和集群等主題的新章節,最終完成瞭這本新版的《Redis 設計與實現》。本書不僅介紹瞭Redis的內部機製(比如數據庫實現、類型係統、事件模型),而且還介紹瞭大部分Redis單機特性(比如事務、持久化、Lua腳本、排序、二進製位操作),以及所有Redis多機特性(如復製、Sentinel和集群)。
雖然作者創作本書的初衷隻是為瞭滿足自己的好奇心,但瞭解Redis內部實現的好處並不僅僅在於滿足好奇心:通過瞭解Redis的內部實現,理解每一個特性和命令背後的運作機製,可以幫助我們更高效地使用Redis,避開那些可能會引起性能問題的陷阱。我衷心希望這本新版《Redis設計與實現》能夠幫助讀者更好地瞭解Redis,並成為更優秀的Redis使用者。
本書的第一版獲得瞭很多熱心讀者的反饋,這本新版的很多改進也來源於讀者們的意見和建議,因此我將繼續在www.RedisBook.com設置disqus論壇(可以不注冊直接發貼),歡迎讀者隨時就這本新版《Redis設計與實現》發錶提問、意見、建議、批評、勘誤,等等,我會努力地采納大傢的意見,爭取在將來寫齣更好的《Redis設計與實現》,以此來迴報大傢對本書的支持。
黃健宏(huangz)
2014年3月於清遠
質量挺好!印刷清晰。
評分我們傢程序員沒說好還是不好,那就是好咯
評分技術男老公的最愛
評分還沒看 應該挺好的
評分同事藉我賬號買的,不知道是什麼情況
評分還沒來得及看,不過質量絕對是正版
評分京東産品就是好,快遞快,快遞服務員態度好,一直信賴京東,下次再來
評分質量非常好,與賣傢描述的完全一緻,非常滿意,真的很喜歡,完全超齣期望值,發貨速度非常快,包裝非常仔細、嚴實,物流公司服務態度很好,運送速度很快,很滿意的一次購物質量非常好,與描述的完全一緻,非常滿意,真的很喜歡,完全超齣期望值,發貨速度非常快,包裝非常仔細、嚴實,送貨員服務態度很好,運送速度很快,很滿意的一次購物
評分介紹的很詳細,深入數據結構實現原理,缺點是沒有介紹基本的安裝配置,還要再找參考資料
Redis設計與實現 pdf epub mobi txt 電子書 下載