用超高速C語言解析Unix下Redis程式及完整執行過程
一次精通Redis、UNIX程式設計、分散式係統、儲存係統
▍本書主要內容
本書深入分析瞭Redis的實現原理,所以並不是Redis的入門書。為瞭儘量降低閱讀難度,本書複習瞭Redis各個核心功能的實現原理,提取瞭Redis核心程式(本書會儘量避免堆積程式),並以適量圖文,對Redis原始程式及其實現原理進行詳細分析,介紹Redis核心功能的設計思想和實現流程。
雖然本書的大部分內容是對Redis原始程式的分析,但是並不複雜,即使讀者隻是簡單瞭解C語言的基礎語法,也可以輕鬆讀懂。
另外,本書結閤Redis目前的最新版本6,分析瞭Redis最新特性,如Redis 6的ACL、Tracking等機製。為瞭照顧對Redis最新特性不熟悉的讀者,這部分內容提供瞭詳細的應用範例,幫助讀者循序漸進、由淺到深地學習和瞭解Redis最新特性。
本書也不侷限於Redis,而是由Redis延展齣瞭兩方麵內容:
(1)Redis中使用的UNIX機製,包括UNIX網路程式設計、執行緒同步等內容,本書會透過原始程式展示Redis如何使用這些UNIX機製。
(2)如何透過Redis實現一個分散式係統,主要是Sentinel、Cluster機製的實現原理。
本書使用的原始程式版本是Redis 6,本書提供的Redis操作案例,如無特殊說明,也是在Redis 6版本上執行的操作實例。
本書特色
.分析Redis的字串、清單、雜湊、集閤這幾種資料類型的編碼格式。
.介紹Redis事件機製與命令執行過程。
.利用I/O重複使用模型,實現事件循環機製。
.說明Redis持久化與複製機製。
.檔案持久化、從節點複製,透過將資料複製到不同備份中,從而保持資料安全。
.使用RDB、AOF持久化機製,以及主從節點複製流程等。
.Redis分散式架構,從流行的分散式演算法Raft齣發,分析Sentinel監控節點,Cluster叢集實現資料分片,支援動態新增、刪除叢集節點,以及容錯移轉。
.說明Redis中的進階特性,包括Redis交易、非阻塞刪除、ACL存取控製清單、Tracking機製、Lua指令稿、Module模組、Stream訊息流等內容。