日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Redis開源文檔《Redis設(shè)計(jì)與實(shí)現(xiàn)》

系統(tǒng) 3189 0

Redis 是運(yùn)用比較廣泛的NoSQL產(chǎn)品之一,目前的穩(wěn)定版本是2.6.10,包括 Github Instagram 、Blizzard、 新浪微博 等都在產(chǎn)品中大量使用了Redis。其代碼基于BSD協(xié)議開源,整個(gè)項(xiàng)目代碼量只有2萬(wàn)多行(2.2版本),大家可以通過(guò)閱讀代碼在相對(duì)短的時(shí)間內(nèi)學(xué)習(xí)到作者的設(shè)計(jì)理念和Redis的實(shí)現(xiàn)方式,做到知其然知其所以然。

日前黃健宏( huangz )發(fā)布了開源文檔 《Redis設(shè)計(jì)與實(shí)現(xiàn)》 ,這是一份從閱讀源代碼入手來(lái)學(xué)習(xí)Redis的筆記合集,對(duì)于寫這份文檔的目的,作者如是說(shuō):

本書的目標(biāo)是以簡(jiǎn)明易懂的方式講解 Redis 的內(nèi)部運(yùn)行機(jī)制, 通過(guò)閱讀本書, 你可以了解到 Redis 從數(shù)據(jù)結(jié)構(gòu)到服務(wù)器構(gòu)造在內(nèi)的幾乎所有知識(shí)。

《Redis設(shè)計(jì)與實(shí)現(xiàn)》主要從高抽象層次在如下的5個(gè)方面對(duì)Redis的實(shí)現(xiàn)進(jìn)行闡述:

  1. 內(nèi)部數(shù)據(jù)結(jié)構(gòu)
  2. 內(nèi)存映射數(shù)據(jù)結(jié)構(gòu)
  3. Redis數(shù)據(jù)類型
  4. 功能的實(shí)現(xiàn)
  5. 部分運(yùn)作機(jī)制

同時(shí)作者為了滿足大家深入學(xué)習(xí)的需求,還對(duì)Redis 2.6的源代碼進(jìn)行了 詳細(xì)注釋

《Redis設(shè)計(jì)與實(shí)現(xiàn)》的作者黃健宏(huangz)是一位90后,喜歡函數(shù)式編程,由于對(duì)數(shù)據(jù)庫(kù)產(chǎn)生了興趣才開始閱讀Redis源代碼,他這樣看待整個(gè)閱讀過(guò)程:

閱讀 Redis 源碼對(duì)我來(lái)說(shuō)是一次全新的學(xué)習(xí)體驗(yàn)。當(dāng)我剛開始看 Redis 源碼的時(shí)候,我只會(huì)一些基本的數(shù)據(jù)結(jié)構(gòu)和算法,沒(méi)有任何網(wǎng)絡(luò)編程、數(shù)據(jù)庫(kù)或者系統(tǒng)編程方面的經(jīng)驗(yàn),基本是一邊看源碼,一邊補(bǔ)充基礎(chǔ)知識(shí),然后才慢慢理解的。

在問(wèn)到閱讀開源項(xiàng)目源代碼時(shí)應(yīng)該參照怎樣的路線,他分享了自己的一些方法:

  1. 自底向上:從耦合關(guān)系最小的模塊開始讀,然后逐漸過(guò)度到關(guān)系緊密的模塊。就好像寫程序的測(cè)試一樣,先從單元測(cè)試開始,然后才到功能測(cè)試。我在剛開始讀 Redis 源碼的時(shí)候,使用的就是這種方法:先從單獨(dú)的數(shù)據(jù)結(jié)構(gòu)模塊開始,然后再過(guò)渡到高層的功能模塊。

  2. 從功能入手:通過(guò)文件名(模塊名)和函數(shù)名,快速定位到一個(gè)功能的具體實(shí)現(xiàn),然后追蹤整個(gè)實(shí)現(xiàn)的運(yùn)作流程,從而了解該功能的實(shí)現(xiàn)方式。我在讀阻塞列表、數(shù)據(jù)庫(kù)這種流程和功能都比較復(fù)雜,和其他文件耦合也比較多的模塊時(shí),使用的就是這樣的方法。

  3. 自頂向下:從程序的 main() 函數(shù),或者某個(gè)特別大的調(diào)用者函數(shù)為入口,以深度優(yōu)先或者廣度優(yōu)先的方式閱讀它的源碼。我在閱讀 redis.c/serverCron() 、 redis.c/main() 和 ae.c/aeMain() 這種有明顯調(diào)用者性質(zhì)的函數(shù)時(shí),使用的就是這樣的方法。

然后他強(qiáng)調(diào):

這三種方法并不互相沖突:在某些函數(shù)/模塊要用某種方法,而某些函數(shù)/模塊要使用另一種方法,有時(shí)候又需要混合使用多種方法。

值得一提的是本書已經(jīng)以“保留所有權(quán)利”的方式開源,大家可以在 github 上查看內(nèi)容的創(chuàng)作過(guò)程,同時(shí)這種開源的協(xié)作方式能讓更多人參與內(nèi)容優(yōu)化中來(lái)。

原文地址: http://www.infoq.com/cn/news/2013/03/redis-book

Redis圖形監(jiān)控工具--RedisLive ??????????

Redis監(jiān)控方案

Redis開源文檔《Redis設(shè)計(jì)與實(shí)現(xiàn)》


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 习水县| 湘西| 略阳县| 东乡县| 右玉县| 平利县| 盐山县| 五大连池市| 轮台县| 望都县| 青浦区| 常宁市| 天全县| 安康市| 保康县| 尚志市| 赤城县| 胶州市| 宁武县| 林周县| 冕宁县| 建阳市| 宜兰市| 汝州市| 麻阳| 清徐县| 闸北区| 荔浦县| 镇巴县| 汉中市| 江油市| 金沙县| 冕宁县| 平果县| 旌德县| 麻江县| 云和县| 星子县| 云浮市| 荣成市| 靖宇县|