關于我們
書單推薦
新書推薦
|
深入分布式緩存:從原理到實踐
書內容在邏輯上共分為三個部分,按照從理論到實現,再到實踐的思路撰寫。首先介紹分布式緩存的背景知識,對本書“分布式”和“緩存”這兩個關鍵詞進行了全面的綜述,作為后續(xù)章節(jié)敘述的基礎;第二部分介紹業(yè)界主流的緩存,關注其原理與實現,囊括了Ehcache、Memcached、Redis、tair、EVCache、Aerospike等六個緩存或類緩存系統(tǒng);后一部分討論緩存在互聯網系統(tǒng)中的實踐,從廣告、社交、新聞、電商、營銷等五類典型的互聯網應用入手,分析它們面臨的性能穩(wěn)定性問題以及如何利用分布式緩存解決這些問題。
來自螞蟻金服、京東、網聯、新浪微博、同程旅游等公司的10余位一線架構師用心之作;
阿里研究員蔣江偉、易寶支付CTO陳斌、普元信息CTO焦烈焱、特贊科技CTO黃勇、微博研發(fā)副總經理楊衛(wèi)華等專家聯袂推薦
深度解構Ehcache、Memcached、Redis、tair、EVCache、Aerospike等6大緩存系統(tǒng)的技術原理,及其在電商、社交、廣告等典型場景中的應用
Praise贊譽
本書圍繞分布式緩存的基礎概念、開源框架、應用案例三方面進行講解,從理論到實戰(zhàn),循序漸進,深入淺出?赐瓴糠终鹿(jié)后,意猶未盡,欲罷不能。國內基于真實應用案例的好書太少了,君澤以及他的朋友們做到了這一點,十分期待這本書能早日上市。
—黃勇特贊科技CTO、《架構探險》作者
分布式緩存,是任何一個互聯網公司在成長過程中都會面臨的技術難題。本書作者結合理論研究和長期的互聯網行業(yè)從業(yè)經驗,深入淺出地介紹了分布式系統(tǒng)理論和分布式緩存實戰(zhàn),給業(yè)界以借鑒和啟發(fā)。本書是作者們的用心之作。
—朱攀德比軟件架構師
緩存是軟件性能優(yōu)化的大殺器,分布式緩存是網站架構的必殺技,玩轉緩存就玩轉了網站架構的半邊天。遺憾的是,目前市面上專門講述分布式緩存的書籍不多,幸運的是本書就是一本這方面的專著。本書所有作者都是多年工作在網站架構一線的老司機,值得信賴,故將本書推薦給大家。
—李智慧《大型網站技術架構:核心原理與案例分析》作者
從十幾年前的Ehcache到最近幾年流行的Redis,從CDN、瀏覽器、API Gateway到后端微服務,以及數據訪問層的二級緩存,緩存無處不在。在體驗為王、唯快不破的時代,分布式緩存是關鍵。本書從理論到實踐,詳細剖析了分布式緩存的實現原理以及應用案例,是一本接地氣的好書。
—李林鋒華為PaaS平臺架構師、公司總裁技術創(chuàng)新獎獲得者
隨著現代應用對速度的要求越來越高,對緩存機制的使用也越來越常見、越來越頻繁。本書以緩存機制的基本原理為開始,逐漸過渡至緩存系統(tǒng)的組建以及使用上面,全書分析和講解了多個緩存系統(tǒng),并列舉了緩存的各種使用場景。如果你正準備構建自己的緩存系統(tǒng),又或者你想進一步學習更多與緩存有關的知識,那么這本書將是你不容錯過的一本書。
—黃健宏《Redis設計與實現》作者
在計算機的世界里,不論硬件層面還是軟件層面,緩存都被廣泛應用于解決處理響應慢的瓶頸。我們在構建微服務架構系統(tǒng)的時候也一樣,緩存是提升性能的關鍵技術手段。然而,緩存在不同場景下的應用各有不同,要想用對緩存、用好緩存并不容易。本書針對不同的緩存類型、實現手段、算法策略做了非常細致的講解,所以我推薦開發(fā)者和架構師們通過本書來對緩存做一次全面的學習,這有助于更好地使用緩存來優(yōu)化我們的系統(tǒng)性能。
—翟永超《Spring Cloud微服務實戰(zhàn)》作者
不同的存儲介質,讀寫性能有很大的差異,價格亦是如此,性能越好的介質,價格就越高。把最常訪問的數據放在讀寫性能最好的設備上,達到成本和性能的均衡,這便誕生了緩存。本書的幾位作者都是大型分布式環(huán)境下歷練出來的沙場老將,豐富的經驗和翔實的案例,對于互聯網行業(yè)的技術人員來說,頗有裨益。
—陳康賢《大型分布式網站架構設計與實踐》作者、阿里巴巴技術專家
如今的軟件系統(tǒng),已經成為分布式系統(tǒng)的天下。分布式的語境對系統(tǒng)的設計與開發(fā)提出了完全不一樣的挑戰(zhàn),作為提升性能的關鍵要素—緩存,自然也不例外。在緩存的命中、更新與失效,以及數據一致性保障等諸多方面,分布式緩存應用的復雜度可能是按指數級增加的,許多問題都是我們在單機應用上無法涉獵的。倘若沒有分布式系統(tǒng)設計的實戰(zhàn)經驗,面對分布式緩存的諸多問題,我們將束手無策。求助于網絡?講解緩存知識的文章是片鱗半爪,未成體系,故而無法窺其全部。本書的幾位作者都經歷過大型軟件系統(tǒng)的深度洗禮,書中內容都來自他們的一線實戰(zhàn)。閱讀本書,讀者就能站在他們的肩膀上看得更遠,實在是幸運!
—張逸民航信息技術架構師、《恰如其分的軟件架構》譯者
緩存是當前互聯網的基石,極大彌補了關系型數據庫的天然缺陷。緩存技術也是每一個架構師的必修課,從最初的Memcached,到Redis及各種擴展架構,發(fā)展至今已經有些百花齊放的感覺。本書難得地進行了全面梳理,并附以在電商、社交、廣告等典型場景下的大型應用。你值得擁有。
—蕭田國高效運維社區(qū)發(fā)起人、DevOpsDays中國聯合發(fā)起人
緩存是互聯網架構中最關鍵的環(huán)節(jié),本書作者在緩存的性能及高可用方面有豐富的經驗,很高興看到他們通過本書分享了多年的實踐精華。
—楊衛(wèi)華微博研發(fā)副總經理
互聯網高性能系統(tǒng)設計的核心之一就是緩存系統(tǒng)的設計。本書集合了緩存理論、開源緩存系統(tǒng)、大規(guī)模業(yè)務中緩存的具體實踐,全方位解讀了分布式緩存設計,既能夠幫助讀者深入理解分布式緩存系統(tǒng),又提供了很好的架構設計案例供參考,細細品讀,受益良多!
—李運華阿里游戲資深技術專家、《面向對象葵花寶典》作者
推薦序1 Foreword
緩存技術的大規(guī)模使用是互聯網架構區(qū)別于傳統(tǒng)IT技術最大的地方,對緩存的理解和使用的深度決定了是否能架構出一個高性價比、高擴展性的系統(tǒng)。阿里巴巴的系統(tǒng)使用了大量緩存技術(內部緩存的產品名字叫Tair)。從2007年開始,緩存服務器的增長速度遠遠超過了數據庫服務器的增長速度,而因為對緩存的充分使用,系統(tǒng)具備的吞吐量能力的增速又遠遠高于緩存本身規(guī)模的增速。這是一件非常劃算的事情,成本下降非常明顯,大概使用1臺緩存服務器就可以完成以前4臺服務器的工作,從而為整體集群節(jié)省3臺服務器。
緩存代表了高性能的一項技術,同時緩存也是系統(tǒng)架構里非常核心的部分,一個系統(tǒng)緩存承擔著90%以上的熱點流量,緩存出一點點問題,系統(tǒng)的可用性會馬上受到影響。在阿里巴巴的系統(tǒng)架構討論會上,一般都會把做緩存產品的同事叫上,要求其在了解系統(tǒng)架構規(guī)模的前提下給出流量規(guī)模、分區(qū)方案、熱點節(jié)點等方面的建議。負責緩存產品的同事往往也需要對業(yè)務有所了解,否則就不能設計出更好的產品。緩存的使用也使得架構更加清晰、更容易理解,流量走向變得更簡單,這使得系統(tǒng)持續(xù)可用性有了明顯的提升。
本書比較系統(tǒng)地介紹了緩存在各個層面的工作原理、作用和價值。理解了緩存的相關知識,會對架構一個高性能分布式系統(tǒng)有很大的幫助。
—小邪(蔣江偉)阿里研究員
Foreword推薦序2
無處不在的緩存,空間換時間的藝術
Cache這個詞,據說來自于法語,本意是當CPU處理數據時,先到Cache中去尋找,如果數據在之前的操作已經讀取而被暫存其中,就不需要從主內存(Main memory)中讀取。后來Cache的范圍有所擴大,凡是位于速度相差較大的兩種硬件之間,用于協(xié)調兩者數據傳輸速度差異的結構,都稱為Cache。
現在,我們談的緩存,已經遠遠突破了原有的概念,在我看來,緩存是一種通用的設計模式:這種模式利用增加存儲空間的方式,實現低速部件與高速部件之間的解耦。換而言之,只要實現了解耦的地方,就有存在緩存的可能,既然解耦是計算機系統(tǒng)架構設計中最常用的手段,那么緩存就必將在計算機系統(tǒng)中無處不在。緩存用空間換時間的方式解決問題,而空間不可能無限使用,使用緩存時我們通常會考慮如何選擇存儲方式、如何使用多級緩存節(jié)省空間、如何有效提高緩存的命中率、如何確定有效的更新策略等問題,這些思考會有相當普遍的適用性。
本書重點解讀了分布式系統(tǒng)下如何使用緩存。分布式系統(tǒng)中大規(guī)模使用緩存是從早期互聯網三大法寶(MemCache、反向代理、分庫分表)開始的,利用這種集中式、大規(guī)模的緩存技術,我們解決了數據庫低速IO與高速應用之間的矛盾。我們也發(fā)現,除了緩存的通用問題之外,分布式系統(tǒng)緩存還需要解決更多的問題,例如如何對多種類型數據選擇不同的存儲方式、如何保證數據一致性、如何提高緩存自身的可用性、如何增強系統(tǒng)的可維護性。為了系統(tǒng)性解決這些問題,分布式緩存逐漸變成了分布式架構系統(tǒng)中的一個基礎設施。
緩存的使用雖然廣泛,但把緩存作為一種基礎設施的發(fā)展歷史并不長,大多數的商業(yè)化軟件比較復雜,主要以內存數據庫為主,而輕量型分布式緩存在不同場景下有不同的關注點和使用方式。君澤集合了一批老司機,為大家展示了多種分布式系統(tǒng)中緩存的使用場景與方案,既有新浪微博這樣重量級社交平臺信息聚合、分發(fā)緩存的方法,也有海量廣告業(yè)務信息撮合的緩存模式;既有電商系統(tǒng)冷熱數據分離的緩存策略,也有對完整分布式系統(tǒng)緩存的技術選型和總結。
通過分布式、微服務架構,實現業(yè)務的云化/數字化,建立起的應用生態(tài)是一個復雜的體系,其中方方面面的著作很多,但專注在緩存方面的還沒有,本書選擇了這個方向,就是希望能幫助我們形成一個完整的技術視圖,我相信這是作者們做這件事的初衷。
—焦烈焱普元信息CTO
Foreword推薦序3
緩存為王
君澤人很低調也很友善,第一次和他見面還是在2016年的年底。2017年的春夏之交,當我正在機場為飛機晚點心煩不已的時候,收到了君澤的一條微信。內容是說他自己正在忙著準備一本書,而且把主要的章節(jié)內容發(fā)給了我。在百無聊賴之間我就讀了起來。
這本書是君澤組織國內互聯網技術領域具有實戰(zhàn)經驗的部分專家,分工合作聯合撰寫的技術專著。以最常用、最有效果也最容易出問題的緩存為主題。從基礎概念、開源框架和應用案例三個層次進行了討論。給我的感覺是既有理論也有實踐,既有廣度也有深度,既有國外的開源軟件也有國內的具體實踐案例,是非常值得深入閱讀和細心揣摩的一本工具書。
給我印象比較深刻的是開篇的“緩存為王”,因為今年年初我也專門寫過一篇同名的文章,論述了從網絡靠近用戶端的CDN,到內部網絡緩存,到應用緩存,再到數據庫緩存的一系列緩存手段、技術和方法。不敢說英雄所見略同,至少大家的關注點差不多。我還記得在當初的文章中用了一句耐人尋味的話,“解決雪崩問題的最好辦法是不發(fā)生雪崩”。不論是在硅谷互聯網公司里還是在國內的互聯網平臺上,曾多次遇到過海量規(guī)模的交易瞬間吞噬平臺的悲慘故事。核心的解決方案大同小異,都是通過緩存,逐層減少流量的沖擊,保護用戶的體驗和平臺的服務可用。金融、財務行業(yè)有現金為王的說法,互聯網技術行業(yè)用“緩存為王”清楚地概括了緩存的重要性。
這本書還深入淺出地討論了Ehcache、Memcached、Redis、Tair、EVCache等各種常用緩存開源系統(tǒng)的方案及精粹。我讀過不少國外有關緩存的技術專著,大多數偏原則和理論,具體實施方案和案例較少,特別是結合中國互聯網技術實踐的更少。所以君澤組織的這本書實際上填補了緩存技術文獻在這方面的空白。尤其是結合微博、社交和電商平臺的應用實踐探討,對想學習如何利用緩存技術解決實踐中具體問題的讀者大有裨益。
—陳斌易寶支付CTO
作者寄語Foreword
我在這部書里,負責編寫了Tair章節(jié),合作編寫了緩存周邊、動手寫緩存章節(jié),期間閱讀了大量的代碼、整理了非常多的資料,希望能帶給讀者需要的知識。在一年多的時間里,工作之余的大部分時間,都投入到了書的編寫中。在這個過程中,家人給了我極大的支持,這里特別感謝我的太太李春花。一年多的時間里,有因為大促工作量激增,有因為工作變動導致工余時間減少,感謝右軍持續(xù)的鼓勵,感謝一同編寫本書的其他伙伴及時的幫助!
—劉璟宇拍拍貸資深架構師
很幸運,從2009年新浪微博發(fā)展之初就參與微博平臺系統(tǒng)的的研發(fā)及架構工作,經歷了微博從起步到當前月活用戶數億的大型互聯網系統(tǒng)的技術演進過程。系統(tǒng)演進中經歷了很多曲折、困難、不眠之夜,多虧了 TimYang、 zhulei、 liudaoru等那么多良師益友,一路上大家志同道合披荊斬棘,回頭看經歷的種種困難卻正好是不斷進步的印記。最后感謝 右軍的邀請和大力組織,感謝 Mis曉曉的包容和支持,正因為有了你們,我才得以完成相關內容的編寫和完善。
—陳波新浪微博平臺架構技術專家
從事數據訪問層工作期間,會收到很多緩存方面的技術支持,在支持的同時,對緩存也有了更深入的了解,也促使我思考如何將這些實踐經驗分享給更多的人。正好右軍邀請參與本書的寫作,便欣然同意。寫作期間,閱讀了大量的源碼,并和聯合作者相互交流緩存的原理及實踐經驗,力求能夠呈現實用的技術。本書涉及的分布式緩存體系非常全面,從分布式、Redis、Memcached等原理的剖析到大量的一線實踐案例,并且對分布式緩存應用當中的一些痛點、難點進行了深入的闡述。希望本書能夠為想了解緩存技術的讀者帶來快樂和收益。
—何濤唯品會架構師
承右軍兄邀請,有幸參與本書第11章“Aerospike原理及廣告業(yè)務應用”的編寫。本人雖然在互聯網廣告行業(yè)摸爬打滾十余年,從廣告網絡到SSP、DSP,再到蘋果應用市場的推廣(ASO,ASM),從PC廣告到移動原生廣告都有所涉及。對于廣告系統(tǒng)架構搭建(存儲,計算,緩存)以及系統(tǒng)的高可用較熟悉之外,對于寫書確實是趕鴨子上架頭一回。又由于平時工作繁忙,家里瑣碎事情亦多,幾有放棄之念想,但此事絕非君子所為。若如此辜負右軍兄及其他幾位一同寫書的弟兄,于心不忍,日后亦無顏面對他們。故硬著頭皮,把此章寫完并交付出版社。聽聞此章定稿之后,感覺如釋重負,精神亦有所高漲。當然,能夠堅持下去的另一個重要原因是,其他各位參與編寫本書的弟兄的鞭策和鼓勵。在這里要特別感謝右軍和老曹。由于本人水平有限,還望各位親愛的讀者海涵。
—宋慧慶勤誠互動高級架構師
首先非常感謝右軍兄邀請我加入寫作團隊,我主要負責第3章、第4章,同此參與合作編寫了第6章。雖然我自己經常寫一些博客文章,但是寫書和寫博客是完全不一樣的過程,寫書是要能夠帶領讀者逐步深入學習,而不是簡單地將知識點羅列出來。在這個過程中非常感謝右軍和孫海亮對我進行認真的指導,讓我的寫作水平有了非常大的提高。當我第一篇稿子定稿的時候,我內心的成就感是很難用言語來表達的。由于本書的寫作時間周期比較長,在中途的過程中由于工作繁忙,我也曾經有退出的想法,右軍和曹哥給了我巨大的鼓勵,讓我學會了堅持,同時我的妻子和我的父母也給了我巨大的支持,讓我能夠學會與團隊協(xié)作。對于我來講這本書對我的意義已經超過內容本身的范疇,我也希望通過這本書能夠給我的孩子樹立一個貴在堅持和勇于嘗試的榜樣。最后由于本人寫作水平有限,還請各位讀者朋友海涵和包容。
—程超愛農驛站首席支付技術專家
Web應用相對于傳統(tǒng)的軟件,在服務的吞吐量方面有更高的要求,也是其面臨的主要難點之一。對于無狀態(tài)的應用服務,日益增加的吞吐量最終轉化成存儲層的壓力,使得后者既要解決數據一致性問題,又要考慮性能和吞吐量,成為Web應用性能的關鍵,因此已有的文檔和書籍主要聚焦在它的優(yōu)化上。
而緩存作為應用服務節(jié)點和持久化存儲節(jié)點間的輔助層,分擔著后者的吞吐量需求,好的緩存設計可以極大地降低存儲層的容量風險。本書從緩存的原理、實現到緩存在不同場景的實施方案給出系統(tǒng)化的介紹,為“好的緩存設計”提供了指導。因此在受邀參與本書編寫時,既感到榮幸,又感到意義重大。
好的寫作依賴于熱情和投入,而書籍的編寫又需要長時間的毅力和堅持,這讓本書的編寫像是一段長跑里需要不斷沖刺,也讓這份“意義重大”既是之于內容本身,也是之于作者的自我提升。感謝本書主筆于君澤的堅持,也感謝其他每一位作者的投入,他們鞭策著我在此領域學習和思考。限于自己的水平,謹希望所編寫的章節(jié)能為讀者們帶來一點幫助。內容有欠缺之處,也希望讀者批評指教,以此驅動這個領域的應用和實踐持續(xù)演進。
—邱碩螞蟻金服技術專家
作為一個70后的老碼農,一個半吊子全棧工匠,在中生代技術(freshman Technology)社區(qū)有幸認識了很多志同道合的技術人。因為自己在公眾號(wireless_com)上的一篇關于緩存基礎的隨筆而結識了 右軍,進而參與了本書的創(chuàng)作。在如今用戶體驗至上的時代,性能成為系統(tǒng)設計中的一種核心約束,在性能提升的各種技術手段中,緩存為王。隨著技術的演進,緩存同樣與時俱進。參與編寫的過程是一個對經驗梳理的過程,同時也是一個人提升的過程,尤其是和各位作者的切磋,獲益匪淺。每一位作者都犧牲了大量的閑暇時間,為本書的出版付出了巨大的努力。我感謝自己的妻兒,感謝家人對自己的支持,希望這本書能夠不負眾望。
—曹洪偉渡鴉科技CTO
2014年加入京東后,負責重新設計詳情頁架構,它是一個讀服務,從前端瀏覽器到后端存儲無處不用緩存,在實戰(zhàn)中通過運用大量緩存技術提升性能、解決棘手問題,比如618期間有人來刷你的接口,簡單上個緩存,會起到很大的保護作用,而且效果非常好。在運用緩存時有許多需要注意的地方,比如緩存一致性是否需要強一致;價格庫存數據能否緩存,緩存多久;緩存分布算法是使用一致性哈希還是取模算法;熱點數據怎么處理;緩存崩潰與快速恢復等等。要用好緩存并不是那么容易的,希望讀者看完本書后能學到一招半式并應用到實戰(zhàn)中。
—張開濤京東架構師
緩存在整個高并發(fā)架構設計中是重中之重的關鍵一筆,所以用好緩存是每次架構設計的必經之路。感謝右軍邀請我參與本書。我在本書中介紹了同程旅游的鳳凰緩存系統(tǒng)(phoenix)是如何云化管理同程全部的緩存集群,并治理各應用中的緩存使用的。也講述了一些我們?yōu)楹我_發(fā)phoenix來解決緩存問題的坑事;厥走@些坑事,歷歷在目。各種困難、各種痛苦伴隨著鳳凰緩存系統(tǒng)從構想到多個版本的更新上線。希望本書能夠給踩到同樣坑事的讀者帶來幫助和快樂。
—王曉波同程旅游首席架構師
Preface前言
為了初心的紀念
一本歷時2年的書即將出版難免有些激動,同時亦有些忐忑。激動在于這是一次有意義的社會實踐,諸多作者參與其中。至完稿時,作者與發(fā)起計劃時已有些不同。一些朋友因為各種原因退出了,所以從堅持的角度看,完成就意味著第一層面的成功。忐忑在于從初心出發(fā),通讀全稿仍有不足之處,諸位作者在具體實踐中所遇到的線上問題遠非本書所能盡數容納。而最后精華的實踐章節(jié)亦經過公司PR審核,略有刪減。再一層,設計和編碼很重要,運維管理同等重要。一個好用、易用、穩(wěn)定的運維工具也是選擇一套開源組件的重要參考因素,為了集中注意力,本書基本未覆蓋運維部分的內容,且待有心人續(xù)之。寫一本書,面世之后,作者或喜或憂,因為臧否之權利在于讀者。
自覺而言,本書適合有一定研發(fā)經驗的朋友閱讀,它山之石,亦有攻玉之效。本書在邏輯上可分為三大篇章:基礎概念篇、開源框架篇、應用案例篇。基礎概念除了基礎知識,也介紹了一些分布式方面的方法和思路;開源框架篇遴選了近年來流行的框架(比如Redis),同時對淘寶Tair、EVCache也做了一些探索。在Redis大行其道之時,對于Memcached及其周邊知識也做了介紹,某些公司還有大量的Memcached實例,比如微博、Twitter等。工具的革新總是源自需求的不斷被滿足,而根據被滿足的特性可以歸納其共性,比如解決單點高可用問題就是一個普適性問題,涉及主從模式、雙活模式等,可用性同時又和性能、數據一致性相關。緩存為性能而生,但“緩存”設施的存在就決定了這個設施要符合分布式理論的要求。業(yè)界介紹理論和概要,或介紹設計原則的書不少,但拿出具體實踐的稀有,比如新浪微博、Twitter這樣的社交SNS具體如何設計緩存。簡約而不簡單!在應用案例篇,筆者邀請了對應領域的專家為大家解讀案例,可以讓大家觸摸到真實的設計意圖。重要的是大家可以獲得不同場景下不同設計策略的啟發(fā)。
本書的產生要追溯到多年前。筆者一直對緩存技術抱有熱情,關注開源框架的發(fā)展,亦在工作中關注所遇、所見,乃至所聽的案例。從應用程序研發(fā)方面看分布式緩存,并不需要所有的程序員都具備開發(fā)一套組件的能力,但是需要具備正確使用它的能力。正如易寶CTO陳斌老師所言:“解決雪崩問題的最好辦法是不發(fā)生雪崩”。不論是在硅谷互聯網公司里還是在國內的互聯網平臺上,曾多次遇到過海量規(guī)模的交易瞬間吞噬平臺的悲慘故事。筆者亦了解一些緩存因為代碼缺陷或者使用不當被擊穿的案例,不同數量級的請求產生的結果有天壤之別,不可不慎。
兩年前偶遇機械工業(yè)出版社的楊福川老師,攀談之下就萌發(fā)了創(chuàng)作本書的念頭。但由于工作繁忙且想呈現心中所想之提綱,故邀請一些不同場景下的專家共同完成。組團過程多有波折,特別感動的是北京的孔慶龍兄。他非常有興趣參與合作,但時逢小孩即將出生,為此,孔兄開了一次家庭會議來討論此事。雖然孔兄后續(xù)未決定參與,但可見其待人之真、之誠,是值得交的朋友。兩年間發(fā)生了不少事情,劉暻宇(leo)、何濤、曹洪偉和程超都換了工作。在本書項目開始時程超家的小朋友還未出生,現在都快2歲了。大家都很忙,大約1個月碰一下進度,有時候可能一點進展都沒有。期間,程超和leo都一度要退出,終堅持了下來。還有些朋友中間退出了,同時有陳波、王曉波等朋友加入。到這時,啥時候出版已不那么心焦了,水到渠成。就是問初心,我們有沒有盡自己的努力來呈現一份關于工具書的紀念?
特別感謝曹洪偉身體力行,按時按質完成了分配的章節(jié),同時review了不少章節(jié),帶動了這個虛擬組織邁上一個新臺階。這是一本書的編寫過程,是一次心靈的旅行,是一次基于互聯網的跨組織協(xié)同,也是關于工作和生活的點綴。感謝妻子曉娜對于我寫作的支持,她對于進度的關注甚于我自己。她花了大量的時間輔導兩個小朋友的學習,雖然周末有輔導班、家務等各種事項,但我總能申請到一些時間來構思本書。本書也是送給我的兩個寶貝的禮物。這個禮物是初心,想到什么有意義的事情要義無反顧去做;同時,這個禮物也代表“堅持”,如同寫作文一樣,觀察、總結,然后不斷練習。
同時還要感謝所有的合作者,我們交叉review了所有章節(jié)。感謝機械工業(yè)出版社的楊福川老師、孫海亮老師。孫老師的審閱非常專業(yè),從讀者視角直面問題所在。朱攀兄弟review了部分章節(jié),在寫作過程中和高磊兄弟、丁浪兄弟也有交流,一并表示感謝。
囿于篇幅和知識局限,錯漏之處難免,后續(xù)將通過勘誤和調整完善的形式持續(xù)優(yōu)化。為了初心的紀念,一次心靈的旅游!祝大家閱讀愉快!
于君澤(右軍)
于君澤:螞蟻金服高級技術專家、花名右軍,IT從業(yè)超過十五年。對高并發(fā)、分布式架構、內建質量、研發(fā)管理有一些心得。維護公眾號“技術瑣話”。
程超:“愛農驛站”首席支付技術專家。InfoQ、中生代技術社區(qū)簽約作者,CSDN博主專家,Spring for all社區(qū)貢獻者,擅長微服務和分布式架構。
邱碩:螞蟻金服技術專家,花名牧丘,在阿里和支付寶從事中間件、應用系統(tǒng)的性能/穩(wěn)定性技術風險相關工作。Cobar主要作者。
曹洪偉:70后老碼農,全棧工匠一枚,服務過多家世界500強,后連續(xù)創(chuàng)業(yè),現任渡鴉科技CTO,致力于人工智能硬件,維護有“wireless_com”公眾號和博客
劉璟宇:拍拍貸資深架構師,十余年互聯網行業(yè)從業(yè)經驗,主要研究云計算、服務化基礎框架以及各種基礎組件。
張開濤:京東架構師,暢銷書《億級流量網站架構核心技術》作者,維護有“開濤的博客”公眾號。
何濤:網聯高級架構師,對高流量下的架構設計有豐富的實踐經驗,熱衷于高可用、高并發(fā)和高性能的架構研究。
宋慧慶:勤誠互動研發(fā)總監(jiān)兼高級架構師,十年互聯網廣告行業(yè)經驗,主要研究高可用架構技術,為流量變現提供更好的服務。
陳波:新浪微博技術專家,負責平臺基礎架構及優(yōu)化,經歷了微博從起步到成為數億用戶的大型互聯網系統(tǒng)的演進過程。
王曉波:同程旅游首席架構師,10余年互聯網行業(yè)從業(yè)經驗,負責中間件、微服務、分布式架構、運維、安全等方面工作。
Contents 目錄
贊譽
推薦序1
推薦序2
推薦序3
作者寄語
前言
第1章 緩存為王1
1.1 什么是緩存?1
1.2 為什么使用緩存?2
1.2.1 從用戶體驗說起3
1.2.2 關于系統(tǒng)的性能3
1.3 從網站的架構發(fā)展看緩存4
1.4 客戶端緩存5
1.4.1 頁面緩存6
1.4.2 瀏覽器緩存7
1.4.3 APP上的緩存8
1.5 網絡中的緩存11
1.5.1 Web代理緩存11
1.5.2 邊緣緩存12
1.6 服務端緩存14
1.6.1 數據庫緩存14
1.6.2 平臺級緩存16
1.6.3 應用級緩存18
第2章 分布式系統(tǒng)理論24
2.1 分布式系統(tǒng)概論24
2.2 分布式系統(tǒng)概念26
2.2.1 進程與線程26
2.2.2 并發(fā)26
2.2.3 鎖26
2.2.4 并行27
2.2.5 集群27
2.2.6 狀態(tài)特性28
2.2.7 系統(tǒng)重發(fā)與冪等性28
2.2.8 硬件異常30
2.3 分布式系統(tǒng)理論31
2.3.1 CAP理論32
2.3.2 CAP理論澄清34
2.3.3 Paxos35
2.3.4 2PC38
2.3.5 3PC39
2.3.6 Raft40
2.3.7 Lease機制41
2.3.8 解決“腦裂”問題43
2.3.9 Quorum NWR44
2.3.10 MVCC45
2.3.11 Gossip46
2.4 分布式系統(tǒng)設計策略49
2.4.1 心跳檢測50
2.4.2 高可用設計50
2.4.3 容錯性52
2.4.4 負載均衡53
2.5 分布式系統(tǒng)設計實踐54
2.5.1 全局ID生成54
2.5.2 哈希取模56
2.5.3 一致性哈希57
2.5.4 路由表58
2.5.5 數據拆分58
第3章 動手寫緩存60
3.1 緩存定義的規(guī)范60
3.1.1 新規(guī)范的主要內容及特性60
3.1.2 新規(guī)范的API介紹61
3.2 緩存框架的實現62
3.2.1 前期準備63
3.2.2 緩存的架構介紹63
3.2.3 設計思路以及知識點詳解64
3.3 緩存框架的使用示例74
第4章 Ehcache與Guava Cache76
4.1 Ehcache的主要特性76
4.2 Ehcache使用介紹77
4.2.1 Ehcache架構圖77
4.2.2 緩存數據過期策略78
4.2.3 Ehcache緩存的基本用法81
4.2.4 在Spring中使用Ehcache83
4.3 Ehcache集群介紹85
4.3.1 集群的方式86
4.3.2 如何配置集群88
4.4 Ehcache的適用場景89
4.5 Guava Cache的使用92
4.5.1 Guava Cache的適用場景92
4.5.2 Guava Cache的創(chuàng)建方式93
4.5.3 緩存數據刪除95
4.5.4 并發(fā)場景下的使用95
4.6 本章小結96
第5章 從Memcached開始了解集中式緩存97
5.1 Memcached基本知識98
5.1.1 Memcached的操作命令98
5.1.2 Memcached使用場景100
5.1.3 Memcached特征100
5.1.4 Memcached的一些問題101
5.2 Memcached內存存儲102
5.2.1 Slab Allocation機制102
5.2.2 使用 Growth Factor進行調優(yōu)104
5.2.3 Item105
5.3 典型問題解析106
5.3.1 過期機制106
5.3.2 哈希算法107
5.3.3 熱點問題108
5.3.4 緩存與數據庫的更新問題108
5.3.5 別把緩存當存儲109
5.3.6 命名空間110
5.3.7 CAS110
5.4 Memcached客戶端分析110
5.4.1 Memcached的Client111
5.4.2 Spymemcached設計思想解析111
5.5 Memcached周邊工具發(fā)展117
第6章 Memcached 周邊技術119
6.1 Twemcache119
6.1.1 Twemcache 的設計原理120
6.1.2 Twemcache的安裝及命令行詳解122
6.1.3 基于Java的Twemcache用法125
6.2 Twemproxy126
6.2.1 Twemproxy的常用部署模式127
6.2.2 Twemproxy的可擴展性129
6.2.3 Twemproxy源代碼簡析131
6.3 Mcrouter137
6.3.1 Mcrouter路由算法138
6.3.2 典型的使用場景139
6.3.3 Mcrouter的可擴展性142
6.3.4 源碼簡要解析144
第7章 Redis探秘148
7.1 數據結構148
7.1.1 value對象的通用結構149
7.1.2 String149
7.1.3 List152
7.1.4 Map155
7.1.5 Set157
7.1.6 Sorted-Set159
7.2 客戶端與服務器的交互160
7.2.1 客戶端/服務器協(xié)議161
7.2.2 請求/響應模式163
7.2.3 事務模式164
7.2.4 腳本模式168
7.2.5 發(fā)布/訂閱模式169
7.3 單機處理邏輯171
7.3.1 多路復用171
7.3.2 定時任務處理173
7.4 持久化174
7.4.1 基于全量模式的持久化174
7.4.2 基于增量模式的持久化176
7.4.3 基于增量模式持久化的優(yōu)化178
第8章 分布式Redis180
8.1 水平拆分(sharding)181
8.1.1 數據分布181
8.1.2 請求路由182
8.2 主備復制(replication)182
8.2.1 主備復制流程183
8.2.2 斷點續(xù)傳183
8.3 故障轉移(failover)184
8.3.1 sentinel間的相互感知185
8.3.2 master的故障發(fā)現186
8.3.3 failover決策186
8.4 Redis Cluster187
8.4.1 拓撲結構187
8.4.2 配置的一致性188
8.4.3 sharding190
8.4.4 failover193
8.4.5 可用性和性能196
第9章 Tair探秘198
9.1 Tair總體架構198
9.2 Config Server簡介199
9.3 Data Server簡介201
9.4 Tair高可用和負載均衡204
9.4.1 對照表204
9.4.2 數據遷移219
9.5 存儲引擎220
9.6 Tair的API222
9.6.1 key/value相關API223
9.6.2 prefix相關的API226
第10章 EVCache探秘229
10.1 EVCache項目介紹230
10.1.1 EVCache的由來231
10.1.
你還可能感興趣
我要評論
|