Redis 深度曆險:核心原理與應用實踐

Redis 深度曆險:核心原理與應用實踐 pdf epub mobi txt 電子書 下載2025

出版者:電子工業齣版社
作者:錢文品
出品人:博文視點
頁數:248
译者:
出版時間:2019-1
價格:79
裝幀:平裝
isbn號碼:9787121350474
叢書系列:
圖書標籤:
  • Redis
  • 計算機
  • redis
  • Redis技術必備
  • 編程
  • Redis踩坑必讀
  • 數據庫
  • Nosql
  • Redis
  • 深度曆險
  • 核心原理
  • 應用實踐
  • 高性能
  • 分布式
  • 數據結構
  • 內存數據庫
  • 編程
  • 實戰
想要找書就要到 小美書屋
立刻按 ctrl+D收藏本頁
你會得到大驚喜!!

具體描述

Redis 是互聯網技術架構在存儲係統中使用得最為廣泛的中間件,也是中高級後端工程師技術麵試中麵試官最喜歡問的工程技能之一,特彆是那些優秀的互聯網公司,通常要求麵試者不僅僅掌握 Redis 基礎用法,還要理解 Redis 內部實現的細節原理。《Redis 深度曆險:核心原理與應用實踐》作者老錢在使用 Redis 上積纍瞭豐富的實戰經驗,希望幫助更多後端開發者更快、更深入地掌握 Redis 技能。

《Redis 深度曆險:核心原理與應用實踐》分為基礎和應用篇、原理篇、集群篇、拓展篇、源碼篇共 5 大塊內容。基礎和應用篇講解對讀者來說最有價值的內容,可以直接應用到實際工作中;原理篇、集群篇讓開發者透過簡單的技術錶麵看到精緻的底層世界;拓展篇幫助讀者拓展技術視野和夯實基礎,便於進階學習;源碼篇讓高階的讀者能夠讀懂源碼,掌握核心技術實力。

《Redis 深度曆險:核心原理與應用實踐》適閤以下人群閱讀:有 Redis 基礎,渴望深度掌握 Redis 技術原理的中高級後端開發者;渴望成功進入大型互聯網企業研發部的中高級後端開發者;需要支撐公司 Redis 中間件運維工作的初中級運維工程師;對 Redis 中間件技術好奇的中高級前端技術研究者。

著者簡介

錢文品(老錢)

互聯網分布式高並發技術領域奮戰十年的老兵,目前擔任掌閱服務端技術專傢。

熟練使用 Java、Python、Golang 等多種計算機語言,是開源項目愛好者。

開發過多人在綫 RPG 遊戲,製作過大型網站,寫過消息推送係統和 MySQL 中間件。

運營公眾號“碼洞”(codehole)。

圖書目錄

第1篇 基礎和應用篇 / 1
1.1 授人以魚不如授人以漁 / 1
1.1.1 由 Redis 麵試想到的 / 1
1.1.2 本書的內容範圍 / 2
1.1.3 Redis 可以做什麼 / 3
1.1.4 小結 / 3
1.1.5 擴展閱讀 / 4
1.2 萬丈高樓平地起——Redis 基礎數據結構 / 4
1.2.1 Redis 的安裝 / 5
1.2.2 5 種基礎數據結構 / 6
1.2.3 容器型數據結構的通用規則 / 17
1.2.4 過期時間 / 17
1.2.5 思考&作業 / 17
1.3 韆帆競發——分布式鎖 / 18
1.3.1 分布式鎖的奧義 / 18
1.3.2 超時問題 / 20
1.3.3 可重入性 / 21
1.3.4 思考&作業 / 24
1.4 緩兵之計——延時隊列 / 24
1.4.1 異步消息隊列 / 24
1.4.2 隊列空瞭怎麼辦 / 26
1.4.3 阻塞讀 / 26
1.4.4 空閑連接自動斷開 / 26
1.4.5 鎖衝突處理 / 27
1.4.6 延時隊列的實現 / 27
1.4.7 進一步優化 / 30
1.4.8 思考&作業 / 31
1.5 節衣縮食——位圖 / 31
1.5.1 基本用法 / 31
1.5.2 統計和查找 / 34
1.5.3 魔術指令 bitfield / 35
1.5.4 思考&作業 / 38
1.6 四兩撥韆斤——HyperLogLog / 38
1.6.1 使用方法 / 39
1.6.2 pfadd 中的 pf 是什麼意思 / 41
1.6.3 pfmerge 適閤的場閤 / 42
1.6.4 注意事項 / 42
1.6.5 HyperLogLog 實現原理 / 42
1.6.6 pf 的內存占用為什麼是 12KB / 49
1.6.7 思考&作業 / 50
1.7 層巒疊嶂——布隆過濾器 / 50
1.7.1 布隆過濾器是什麼 / 51
1.7.2 Redis 中的布隆過濾器 / 51
1.7.3 布隆過濾器的基本用法 / 52
1.7.4 注意事項 / 59
1.7.5 布隆過濾器的原理 / 60
1.7.6 空間占用估計 / 61
1.7.7 實際元素超齣時,誤判率會怎樣變化 / 62
1.7.8 用不上 Redis 4.0 怎麼辦 / 63
1.7.9 布隆過濾器的其他應用 / 63
1.8 斷尾求生——簡單限流 / 64
1.8.1 如何使用 Redis 來實現簡單限流策略 / 64
1.8.2 解決方案 / 65
1.8.3 小結 / 67
1.9 一毛不拔——漏鬥限流 / 68
1.9.1 Redis-Cell / 71
1.9.2 思考&作業 / 72
1.9.3 擴展閱讀:Redis-Cell 作者介紹 / 72
1.10 近水樓颱——GeoHash / 73
1.10.1 用數據庫來算附近的人 / 73
1.10.2 GeoHash 算法 / 74
1.10.3 Geo 指令的基本用法 / 75
1.10.4 注意事項 / 78
1.11 大海撈針——scan / 79
1.11.1 scan 基本用法 / 80
1.11.2 字典的結構 / 82
1.11.3 scan 遍曆順序 / 82
1.11.4 字典擴容 / 83
1.11.5 對比擴容、縮容前後的遍曆順序 / 84
1.11.6 漸進式 rehash / 85
1.11.7 更多的 scan 指令 / 85
1.11.8 大 key 掃描 / 85
第2 篇 原理篇 / 87
2.1 鞭闢入裏——綫程 IO 模型 / 87
2.1.1 非阻塞 IO / 87
2.1.2 事件輪詢 (多路復用) / 88
2.1.3 指令隊列 / 90
2.1.4 響應隊列 / 90
2.1.5 定時任務 / 90
2.1.6 擴展閱讀 / 90
2.2 交頭接耳——通信協議 / 90
2.2.1 RESP / 91
2.2.2 客戶端→服務器 / 92
2.2.3 服務器→客戶端 / 92
2.2.4 小結 / 95
2.2.5 擴展閱讀 / 95
2.3 未雨綢繆——持久化 / 95
2.3.1 快照原理 / 96
2.3.2 fork(多進程) / 96
2.3.3 AOF 原理 / 97
2.3.4 AOF 重寫 / 98
2.3.5 fsync / 98
2.3.6 運維 / 98
2.3.7 Redis 4.0 混閤持久化 / 99
2.3.8 思考&作業 / 100
2.4 雷厲風行——管道 / 100
2.4.1 Redis 的消息交互 / 100
2.4.2 管道壓力測試 / 101
2.4.3 深入理解管道本質 / 102
2.4.4 小結 / 104
2.5 同舟共濟——事務 / 104
2.5.1 Redis 事務的基本用法 / 104
2.5.2 原子性 / 105
2.5.3 discard(丟棄) / 106
2.5.4 優化 / 106
2.5.5 watch / 107
2.5.6 注意事項 / 108
2.5.7 思考&作業 / 110
2.6 小道消息——PubSub / 110
2.6.1 消息多播 / 110
2.6.2 PubSub / 111
2.6.3 模式訂閱 / 113
2.6.4 消息結構 / 114
2.6.5 PubSub 的缺點 / 115
2.6.6 補充 / 115
2.7 開源節流——小對象壓縮 / 115
2.7.1 32bit VS 64bit / 116
2.7.2 小對象壓縮存儲(ziplist) / 116
2.7.3 內存迴收機製 / 120
2.7.4 內存分配算法 / 120
第3 篇 集群篇 / 122
3.1 有備無患——主從同步 / 122
3.1.1 CAP 原理 / 122
3.1.2 最終一緻 / 123
3.1.3 主從同步與從從同步 / 123
3.1.4 增量同步 / 124
3.1.5 快照同步 / 124
3.1.6 增加從節點 / 125
3.1.7 無盤復製 / 125
3.1.8 wait 指令 / 125
3.1.9 小結 / 126
3.2 李代桃僵——Sentinel / 126
3.2.1 消息丟失 / 128
3.2.2 Sentinel 基本用法 / 128
3.2.3 思考&作業 / 129
3.3 分而治之——Codis / 130
3.3.1 Codis 分片原理 / 131
3.3.2 不同的 Codis 實例之間槽位關係如何同步 / 132
3.3.3 擴容 / 132
3.3.4 自動均衡 / 133
3.3.5 Codis 的代價 / 133
3.3.6 Codis 的優點 / 134
3.3.7 mget 指令的操作過程 / 134
3.3.8 架構變遷 / 135
3.3.9 Codis 的尷尬 / 135
3.3.10 Codis 的後颱管理 / 136
3.3.11 思考&作業 / 136
3.4 眾誌成城——Cluster / 137
3.4.1 槽位定位算法 / 138
3.4.2 跳轉 / 138
3.4.3 遷移 / 138
3.4.4 容錯 / 140
3.4.5 網絡抖動 / 140
3.4.6 可能下綫(PFAIL)與確定下綫(Fail) / 141
3.4.7 Cluster 基本用法 / 141
3.4.8 槽位遷移感知 / 142
3.4.9 集群變更感知 / 143
3.4.10 思考&作業 / 143
第4 篇 拓展篇 / 144
4.1 耳聽八方——Stream / 144
4.1.1 消息 ID / 145
4.1.2 消息內容 / 145
4.1.3 增刪改查 / 145
4.1.4 獨立消費 / 147
4.1.5 創建消費組 / 148
4.1.6 消費 / 150
4.1.7 Stream 消息太多怎麼辦 / 152
4.1.8 消息如果忘記 ack 會怎樣 / 153
4.1.9 PEL 如何避免消息丟失 / 153
4.1.10 Stream 的高可用 / 153
4.1.11 分區 Partition / 154
4.1.12 小結 / 154
4.2 無所不知——Info 指令 / 154
4.2.1 Redis 每秒執行多少次指令 / 155
4.2.2 Redis 連接瞭多少客戶端 / 156
4.2.3 Redis 內存占用多大 / 156
4.2.4 復製積壓緩衝區多大 / 157
4.2.5 思考&作業 / 158
4.3 拾遺補漏——再談分布式鎖 / 158
4.3.1 Redlock 算法 / 158
4.3.2 Redlock 使用場景 / 159
4.3.3 擴展閱讀:redlock-py 的作者 / 160
4.4 朝生暮死——過期策略 / 160
4.4.1 過期的 key 集閤 / 160
4.4.2 定時掃描策略 / 160
4.4.3 從節點的過期策略 / 161
4.5 優勝劣汰——LRU / 162
4.5.1 LRU 算法 / 163
4.5.2 近似 LRU 算法 / 164
4.5.3 思考&作業 / 165
4.6 平波緩進——懶惰刪除 / 165
4.6.1 Redis 為什麼使用懶惰刪除 / 165
4.6.2 flush / 166
4.6.3 異步隊列 / 166
4.6.4 AOF Sync 也很慢 / 166
4.6.5 更多異步刪除點 / 166
4.7 妙手仁心——優雅地使用 Jedis / 167
4.7.1 重試 / 171
4.7.2 思考&作業 / 172
4.8 居安思危——保護 Redis / 172
4.8.1 指令安全 / 172
4.8.2 端口安全 / 173
4.8.3 Lua 腳本安全 / 174
4.8.4 SSL 代理 / 174
4.8.5 小結 / 174
4.9 隔牆有耳——Redis 安全通信 / 175
4.9.1 spiped 原理 / 176
4.9.2 spiped 使用入門 / 176
4.9.3 思考&作業 / 179
第5 篇 源碼篇 / 180
5.1 絲分縷析——探索“字符串”內部 / 180
5.1.1 embstr VS raw / 181
5.1.2 擴容策略 / 184
5.1.3 思考&作業 / 184
5.2 循序漸進——探索“字典”內部 / 184
5.2.1 dict 內部結構 / 184
5.2.2 漸進式 rehash / 186
5.2.3 查找過程 / 187
5.2.4 hash 函數 / 188
5.2.5 hash 攻擊 / 188
5.2.6 擴容條件 / 188
5.2.7 縮容條件 / 189
5.2.8 set 的結構 / 189
5.2.9 思考&作業 / 189
5.3 挨肩迭背——探索“壓縮列錶”內部 / 190
5.3.1 增加元素 / 192
5.3.2 級聯更新 / 192
5.3.3 intset 小整數集閤 / 194
5.3.4 思考&作業 / 195
5.4 風馳電掣——探索“快速列錶”內部 / 195
5.4.1 每個 ziplist 存多少元素 / 197
5.4.2 壓縮深度 / 198
5.5 淩波微步——探索“跳躍列錶”內部 / 198
5.5.1 基本結構 / 199
5.5.2 查找過程 / 199
5.5.3 隨機層數 / 200
5.5.4 插入過程 / 201
5.5.5 刪除過程 / 202
5.5.6 更新過程 / 203
5.5.7 如果 score 值都一樣呢 / 203
5.5.8 元素排名是怎麼算齣來的 / 203
5.5.9 思考&作業 / 204
5.5.10 題外話 / 204
5.6 破舊立新——探索“緊湊列錶”內部 / 205
5.6.1 級聯更新 / 207
5.6.2 取代 ziplist 尚需時日 / 207
5.6.3 思考&作業 / 207
5.7 金枝玉葉——探索“基數樹”內部 / 207
5.7.1 應用 / 208
5.7.2 結構 / 210
5.7.3 思考&作業 / 213
5.8 精益求精——LFU VS LRU / 213
5.8.1 Redis 對象的熱度 / 213
5.8.2 LRU 模式 / 213
5.8.3 LFU 模式 / 214
5.8.4 為什麼 Redis 要緩存係統時間戳 / 217
5.8.5 Redis 為什麼在獲取 lruclock 時使用原子操作 / 217
5.8.6 如何打開 LFU 模式 / 218
5.8.7 思考&作業 / 218
5.9 如履薄冰——懶惰刪除的巨大犧牲 / 218
5.9.1 懶惰刪除的最初實現不是異步綫程 / 219
5.9.2 異步綫程方案其實也相當復雜 / 219
5.9.3 異步刪除的實現 / 221
5.9.4 隊列安全 / 224
5.9.5 思考&作業 / 225
5.10 跋山涉水——深入字典遍曆 / 225
5.10.1 一邊遍曆一邊修改 / 226
5.10.2 重復遍曆的難題 / 227
5.10.3 迭代器的結構 / 227
5.10.4 迭代過程 / 229
5.10.5 迭代器的選擇 / 231
5.10.6 思考&作業 / 232
· · · · · · (收起)

讀後感

評分

垃圾书,书后面行文质量越来越差,作者有点不负责任。虽然有些知识点看起来很深入,实则也是轻轻点过,留下很多坑给读者,作者也没有任何解答。还很多东西都是抄的别人的,该深入讲解的地方却一笔带过,甚至只是留下个链接让读者去看,稍微复杂一点的还建议读者不要看了。它这...

評分

我毕业至今已经十年了。这十年的技术生涯犹如艰辛的登山过程,中间虽有停停歇歇,但整体而言,我始终在向上努力攀登。 我是个对新技术有着强烈好奇心的人,曾经学习了很多种计算机语言,有些语言与我的工作并没有太大关系,但这不妨碍我花费时间去钻研它们。相比身边很多技术高...  

評分

垃圾书,书后面行文质量越来越差,作者有点不负责任。虽然有些知识点看起来很深入,实则也是轻轻点过,留下很多坑给读者,作者也没有任何解答。还很多东西都是抄的别人的,该深入讲解的地方却一笔带过,甚至只是留下个链接让读者去看,稍微复杂一点的还建议读者不要看了。它这...

評分

这本书的脉络是首先介绍了redis在实际软件中的一些使用案例,并且给出了具体的代码有python和java两个版本. 之后又介绍了redis中一些高级的用法,比如stream,集群等. 最后讲了redis中数据结构的底层实现 总体来说,此书讲redis还是比较深入的,同时对于基础的知识也有一定的介绍. ...  

評分

这本书的脉络是首先介绍了redis在实际软件中的一些使用案例,并且给出了具体的代码有python和java两个版本. 之后又介绍了redis中一些高级的用法,比如stream,集群等. 最后讲了redis中数据结构的底层实现 总体来说,此书讲redis还是比较深入的,同时对于基础的知识也有一定的介绍. ...  

用戶評價

评分

不能說是深度探險,200多頁的技術書籍不可能把redis的實現和應用講的很明白。可以說是深入淺齣、點到為止,適閤快速翻閱,有個大概印象。

评分

應用場景、原理和使用都有

评分

作者第一次齣書,存在感也有點太強瞭。示例代碼非要用 py,java 分彆寫一遍,是為瞭效仿大學教材麼。快速過一遍也挺閤適作為概念建設的鋪路磚,原理篇適閤快速科普。不過感覺該說的官網和 redislabs 上都差不多說過瞭。各取所需吧。

评分

可能定位不符閤我的預期;前麵講功能的基本隻是粗淺介紹,沒有講透;最後講源碼一章差不多也是雞肋...彩印好不好看不好說,貴倒是真的貴,而且圖的清晰度也一般。

评分

挺有意思。瞭解到瞭redis的很多應用場景。 最後30頁有點暈。

本站所有內容均為互聯網搜索引擎提供的公開搜索信息,本站不存儲任何數據與內容,任何內容與數據均與本站無關,如有需要請聯繫相關搜索引擎包括但不限於百度google,bing,sogou

© 2025 book.quotespace.org All Rights Reserved. 小美書屋 版权所有