關于我們
書單推薦
新書推薦
|
分布式服務架構
對Java分布式微服務系統(tǒng)架構設計的核心要點逐一介紹,重點的主題配有代碼、設計文檔和開源項目,每個主題獨立成章,代碼下載可在實踐中引用,讓讀者不不但可以了解大規(guī)模分布式微服務系統(tǒng)是怎么設計的,也可以直接將代碼應用到實際項目中,大大提高了讀者在現(xiàn)實中互聯(lián)網(wǎng)項目實現(xiàn)的效率。
《分布式服務架構:原理、設計與實戰(zhàn)》以分布式服務架構為主線,重點介紹了保證服務化架構的一致性、高性能、高可用的解決方案和至佳實踐,并介紹了微服務架構中倡導的容器化過程,以及敏捷開發(fā)和敏捷上線的流程,對分布式服務系統(tǒng)架構設計的核心要點逐一介紹,對重點主題配有代碼、設計文檔和開源項目,每個主題獨立成章,讓讀者不但可以了解大規(guī)模分布式微服務系統(tǒng)是怎么設計的,還可以在了解原理的同時,了解作者在實際項目中積累的至佳實踐和模式,大大提高互聯(lián)網(wǎng)項目的實現(xiàn)效率。要點如下。
√介紹服務化和微服務架構的背景和演化。
√介紹微服務中的常見問題和解決模式。
√提出解決分布式系統(tǒng)一致性問題的有效方案和設計模式。
√介紹酸堿平衡和至終一致性等理論,對分布式服務間出現(xiàn)的服務超時問題給出解決辦法。
√提出非功能質量架構設計的方法論,舉例說明系統(tǒng)的性能和容量的預估,并介紹壓測的方法論和至佳實踐。
√提出服務化的日志系統(tǒng)的技術選型依據(jù)和大數(shù)據(jù)日志系統(tǒng)建設的原理、設計與實戰(zhàn),包括ELK等流行框架的介紹與使用。
√詳細介紹基于調用的APM系統(tǒng)的設計與實現(xiàn),并給出實現(xiàn)的至佳實踐。
√介紹線上應急和技術攻關的流程和重點,并總結Java服務化系統(tǒng)應急中需要使用的Java虛擬機命令、Linux命令和定制化開發(fā)的命令等。
√服務化系統(tǒng)容器化的過程分析和至佳實踐。
√服務化系統(tǒng)中敏捷開發(fā)的過程和工具。
推薦序一
經(jīng)過艷鵬多年的實踐經(jīng)驗積累及長時間的精心準備,本書終于與大家見面了,筆者很榮幸能夠成為本書的首批讀者。
隨著時代的不斷發(fā)展,分布式服務架構日益流行,已經(jīng)從SOA服務化發(fā)展到了微服務架構。有過驚喜,有過質疑,但這未能阻擋分布式服務架構在互聯(lián)網(wǎng)行業(yè)里的普遍應用。然而,事物總是有兩面性的,豐富的新框架及新技術層出不窮,給項目的技術決策者帶來了技術選型上的困難。此外,在互聯(lián)網(wǎng)交易越來越復雜、規(guī)模越來越龐大的背景下,解決分布式服務間的事務問題、業(yè)務一致性問題、可用性問題、穩(wěn)定性問題等的困難以指數(shù)級增加。
本書以一位在IT行業(yè)從事多年分布式服務架構工作的資深老兵的視角,剖析了針對分布式系統(tǒng)架構的解決方案和設計模式。書中的每一章、每一節(jié)都是作者對多年線上系統(tǒng)架構設計實踐的總結。
此外,有別于市面上的其他架構書籍,本書在講解基礎理論和方法論的基礎上,提供了大量的實際操作和詳盡的開發(fā)命令解析,讀者可以直接把書中的方法和案例應用到實際工作中。
如果你想成為一名優(yōu)秀的高并發(fā)服務架構師,那么本書將為你提供實踐指引;如果你在大規(guī)模、高并發(fā)交易系統(tǒng)中遇到問題,那么本書將為你提供解決這些問題的理論與實踐,令你腦洞大開,輕松解決問題!
姚建東
易寶支付產(chǎn)品VP
推薦序二
本書作者艷鵬和楊彪秉著“開放、分享”的態(tài)度,將在互聯(lián)網(wǎng)高并發(fā)服務建設過程中總結的經(jīng)驗、設計模式和最佳實踐整理成書。本書內(nèi)容涉及分布式服務架構的原理、設計與實戰(zhàn),不但介紹了微服務的背景,還介紹了服務化的演進歷史,并詳細介紹了保證一致性、高性能、高可用性的解決方案,重點講解了建設大數(shù)據(jù)日志系統(tǒng)和調用鏈跟蹤系統(tǒng)等內(nèi)容。大數(shù)據(jù)日志系統(tǒng)和調用鏈跟蹤系統(tǒng)是每一個微服務體系都應該包含的核心基礎設施,為服務的穩(wěn)定性、可用性提供了有效保證,為在應急和技術攻關過程中發(fā)現(xiàn)問題、定位問題和恢復問題提供了有效幫助。
本書逐一介紹分布式微服務系統(tǒng)架構設計的核心要點,對重點主題提供了代碼、設計文檔和開源項目,每個主題獨立成章,且相關代碼可應用于實際項目中。通過閱讀本書,讀者不但可以了解大規(guī)模分布式微服務系統(tǒng)是怎么設計的,也可以學到實際服務化項目中的設計模式及最佳實踐,可大大提高互聯(lián)網(wǎng)項目的實施效率。
分布式服務架構涉及的面很廣且難以列舉,涉及架構方法論、設計模式、如何快速入門紛繁龐雜的技術棧、如何對方案進行選型、如何定位和解決問題,等等。筆者也曾面試過許多候選者,其中,能利用所了解的知識較好地解決問題的人不多,能利用當前流行的技術對復雜問題進行技術選型并給出合理架構方案的人更是鳳毛麟角。
筆者曾在Google、樂視等互聯(lián)網(wǎng)企業(yè)工作,作為一名持續(xù)創(chuàng)業(yè)者,曾想將自己從業(yè)以來的項目開發(fā)經(jīng)驗、問題追蹤、技術選型等積累成文字,為給更多的開發(fā)者提供參考,使其少走彎路,但一直礙于各種瑣事未能成行。當艷鵬將書稿呈現(xiàn)在筆者面前并讓筆者為本書作序時,筆者驚喜萬分。本書作者有著多年的一線互聯(lián)網(wǎng)開發(fā)經(jīng)驗,根據(jù)自己的實際生產(chǎn)經(jīng)驗,將微服務、分布式系統(tǒng)、一致性、性能與容量評估、大數(shù)據(jù)日志分析系統(tǒng)、調用鏈系統(tǒng)、容器等結合一些生動、實用的案例進行了全面介紹,對一些項目敏捷開發(fā)和技術選型也給出了自己的經(jīng)驗,同時對日常運維手段也進行了分享。本書雖然篇幅不大但實用性很強,能夠指導實際互聯(lián)網(wǎng)架構的設計與實現(xiàn)。本書主題明確、淺顯易懂,適合初學者和有一定經(jīng)驗的開發(fā)者和架構師閱讀和使用。
于立柱
福佑卡車CTO
推薦序三
本書作者楊彪和艷鵬都是筆者認識多年的老朋友,筆者見證了他們從勤奮青年到老成持重、獨當一面,從一線的核心開發(fā)人員到架構師再到技術經(jīng)理和技術總監(jiān),從傳統(tǒng)IT行業(yè)到互聯(lián)網(wǎng)行業(yè)的心路歷程。
筆者在近幾年面試過很多人,發(fā)現(xiàn)了一些有意思的現(xiàn)象:很多自稱架構師的人在同你講架構時可謂滔滔不絕,各種技術名詞像說相聲一樣從其嘴中說出來,但是你稍微追問一下,就會發(fā)現(xiàn)其存在很多基本概念的缺失,例如自稱精通高并發(fā)的人說不出其所謂的高并發(fā)瓶頸在哪里,自稱能夠開發(fā)高可用和高性能系統(tǒng)的人說不出高可用和高性能的衡量標準是什么,并且其所謂的大數(shù)據(jù)處理系統(tǒng)實際上只有百萬條數(shù)據(jù),等等。
架構師雖然聽起來和工程師沒有太大區(qū)別,技術經(jīng)理和技術總監(jiān)也都會對核心技術有所把控,但本質上架構師要引領技術的發(fā)展,用技術服務于業(yè)務,為業(yè)務產(chǎn)生價值,更通俗地說,架構師需要讓技術變現(xiàn),為客戶賺取更多的利潤,或者為客戶節(jié)省更多的成本,因此,架構師任重而道遠。在互聯(lián)網(wǎng)高速發(fā)展的今天,如何成為一名優(yōu)秀的架構師是一個值得研究的課題,本書正是為那些已經(jīng)成為架構師或者即將成為架構師的人準備的一本好書。作為第一批閱讀本書的讀者,筆者驚嘆于本書中的內(nèi)容如此豐富,囊括了保證互聯(lián)網(wǎng)線上高并發(fā)服務的方方面面,不僅包括分布式服務的背景和演化,還包括保證分布式服務化系統(tǒng)一致性、高性能、高可用的方法論和最佳實踐,而這些正是每一個互聯(lián)網(wǎng)公司都需要探索和應用的理論和方法。筆者推薦每一名互聯(lián)網(wǎng)架構師都閱讀本書,相信你一定能從中學到自己急需的技術、方案和方法。
本書作者有從花旗銀行、甲骨文等知名外企到新浪微博、易寶支付等大型互聯(lián)網(wǎng)平臺,從傳統(tǒng)的核心行業(yè)到火熱的游戲行業(yè),從社交產(chǎn)品到金融支付產(chǎn)品等方方面面的工作經(jīng)驗,既深刻了解傳統(tǒng)行業(yè)的系統(tǒng)規(guī)范、流程和功能的復雜性,又深諳互聯(lián)網(wǎng)行業(yè)的高性能、可用性、高并發(fā)、可伸縮等高級特性。本書涉及的分布式服務架構原理、設計和實戰(zhàn),皆來自于作者在實際工作中提煉的精華,從理論到落地,皆言之有物。無論是對于軟件工程師、測試工程師、運維工程師、軟件架構師、技術經(jīng)理、技術總監(jiān),還是對于資深IT人士來說,本書都極具參考價值。
楊延峰
開心網(wǎng)副總裁
前言
自互聯(lián)網(wǎng)誕生以來,其簡單、敏捷的微服務架構開發(fā)理念和實踐逐漸成為主流,在逐漸發(fā)展的環(huán)境下和技術演化的過程中,迅速突破互聯(lián)網(wǎng)行業(yè)并波及軟件行業(yè)的各個領域。然而,這種突飛猛進的表面下卻是龍魚混雜、泥沙俱下。一方面,很多人在這個信息爆炸的時代應對海量信息的處理能力比較有限;另一方面,也有人致力于將優(yōu)秀的理論和實踐相結合,希望運用所學的高效解決方案應對越來越復雜的問題。不論對與錯,人類對技術進步的追求從未停歇。
毋庸置疑,IT行業(yè)的發(fā)展進入了一個加速分化的時代,將優(yōu)秀的解決方案推向大眾的成本和速度將成為決定企業(yè)生存與否的關鍵因素之一。優(yōu)秀的互聯(lián)網(wǎng)企業(yè)已裝備精良并持續(xù)優(yōu)化,而那些還需不斷進步的企業(yè)也在互相競爭。盡管在這個信息量巨大的媒體時代,部分優(yōu)秀的企業(yè)在應對分布式服務架構時已經(jīng)有了更多的認識且技術越來越完善,但也有很多快速發(fā)展的企業(yè)在變得更優(yōu)秀這條道路上任重而道遠。
很多非常優(yōu)秀的開發(fā)人員和架構師能成為給公司帶來長遠利益的人,在變革的節(jié)點上推波助瀾。本書將帶你走進分布式服務架構的世界,在這個世界里不停探索和汲取經(jīng)驗。領先于別人是一種要求,這也是很多公司贏得先機的關鍵所在,無論服務于IT的哪個領域,每個IT人都有理由重視架構這門藝術。希望本書對于軟件工程師、測試工程師、軟件架構師及深耕于IT行業(yè)的老兵來說,都能帶給其所期望的內(nèi)容,并幫助其解決和發(fā)現(xiàn)問題,也能幫助其不斷探索。
本書以當前流行的分布式服務架構為主線,講解了分布式服務架構的原理、設計與實踐。本書首先介紹了分布式服務架構的背景和演化,然后深入闡述了保證分布式服務的一致性、高性能、高可用性等的設計思想和可實施的方案;然后介紹了大規(guī)模、高并發(fā)線上服務的應急流程和技術攻關過程,并給出了發(fā)現(xiàn)和定位問題的有效、常用工具集;最后詳細介紹了分布式服務架構中容器化過程分析、敏捷開發(fā)和上線的工具,為從事高并發(fā)服務架構的開發(fā)人員提供了保障系統(tǒng)健康運行的方法論和最佳實踐。
感謝電子工業(yè)出版社張國霞編輯的認真態(tài)度和辛勤工作,使得本書能夠最終順利完成。
感謝筆者的技術小伙伴賈博巖提供了日志相關的資料和示例,讓筆者能夠快速完成第4章大數(shù)據(jù)日志系統(tǒng)方面的內(nèi)容。
感謝張曉輝、周偉、霍勇同學在編輯階段參與閱稿,并提出專業(yè)的意見。
感謝英語專業(yè)的高材生曹燕琴小同學在文字上提供的幫助。
最后,感謝筆者的家人和朋友在本書寫作過程中提供的支持和幫助。
李艷鵬
李艷鵬
現(xiàn)任易寶支付產(chǎn)品中心首席架構師,曾在花旗銀行、甲骨文、路透社、新浪微博等大型IT互聯(lián)網(wǎng)公司擔任技術負責人和架構師,現(xiàn)專注于大規(guī)模、高并發(fā)的線上和線下支付平臺的應用架構和技術架構的規(guī)劃與落地,負責交易、支付、渠道、出款、風控、對賬等核心支付系統(tǒng)的設計與實現(xiàn),對移動支付、聚合支付、合規(guī)賬戶、掃碼支付、標記化支付等業(yè)務場景有產(chǎn)品應用架構規(guī)劃與落地的實踐經(jīng)驗。
楊 彪
現(xiàn)任某創(chuàng)業(yè)公司技術總監(jiān)及合伙人,在互聯(lián)網(wǎng)和游戲行業(yè)有近10年工作經(jīng)驗,曾在酷我音樂盒、人人游戲和掌趣科技等上市公司擔任核心研發(fā)職位,在互聯(lián)網(wǎng)公司做過日活躍用戶量達千萬的項目,也在游戲公司做過多款月流水千萬以上的游戲。喜歡研究問題,追求前沿技術,學無止境。
第1章 分布式微服務架構設計原理 1
1.1 從傳統(tǒng)單體架構到服務化架構 2
1.1.1 JEE架構 2
1.1.2 SSH架構 5
1.1.3 服務化架構 8
1.2 從服務化到微服務 11
1.2.1 微服務架構的產(chǎn)生 12
1.2.2 微服務架構與傳統(tǒng)單體架構的對比 13
1.2.3 微服務架構與SOA服務化的對比 15
1.3 微服務架構的核心要點和實現(xiàn)原理 16
1.3.1 微服務架構中職能團隊的劃分 16
1.3.2 微服務的去中心化治理 18
1.3.3 微服務的交互模式 18
1.3.4 微服務的分解和組合模式 22
1.3.5 微服務的容錯模式 35
1.3.6 微服務的粒度 41
1.4 Java平臺微服務架構的項目組織形式 42
1.4.1 微服務項目的依賴關系 42
1.4.2 微服務項目的層級結構 43
1.4.3 微服務項目的持續(xù)發(fā)布 45
1.5 服務化管理和治理框架的技術選型 45
1.5.1 RPC 46
1.5.2 服務化 47
1.5.3 微服務 49
1.6 本章小結 52
第2章 徹底解決分布式系統(tǒng)一致性的問題 54
2.1 什么是一致性 55
2.2 一致性問題 56
2.3 解決一致性問題的模式和思路 57
2.3.1 酸堿平衡理論 58
2.3.2 分布式一致性協(xié)議 61
2.3.3 保證最終一致性的模式 67
2.4 超時處理模式 75
2.4.1 微服務的交互模式 76
2.4.2 同步與異步的抉擇 77
2.4.3 交互模式下超時問題的解決方案 78
2.4.4 超時補償?shù)脑瓌t 85
2.5 遷移開關的設計 87
2.6 本章小結 88
第3章 服務化系統(tǒng)容量評估和性能保障 89
3.1 架構設計與非功能質量 90
3.2 全面的非功能質量需求 91
3.2.1 非功能質量需求的概述 91
3.2.2 非功能質量需求的具體指標 92
3.3 典型的技術評審提綱 97
3.3.1 現(xiàn)狀 97
3.3.2 需求 98
3.3.3 方案描述 98
3.3.4 方案對比 99
3.3.5 風險評估 100
3.3.6 工作量評估 100
3.4 性能和容量評估經(jīng)典案例 100
3.4.1 背景 100
3.4.2 目標數(shù)據(jù)量級 101
3.4.3 量級評估標準 101
3.4.4 方案 102
3.4.5 小結 107
3.5 性能評估參考標準 108
3.5.1 常用的應用層性能指標參考標準 108
3.5.2 常用的系統(tǒng)層性能指標參考標準 109
3.6 性能測試方案的設計和最佳實踐 112
3.6.1 明確壓測目標 112
3.6.2 壓測場景設計和壓測方案制定 114
3.6.3 準備壓測環(huán)境 121
3.6.4 壓測的執(zhí)行 122
3.6.5 問題修復和系統(tǒng)優(yōu)化 123
3.7 有用的壓測工具 123
3.7.1 ab 123
3.7.2 jmeter 125
3.7.3 mysqlslap 125
3.7.4 sysbench 129
3.7.5 dd 134
3.7.6 LoadRunner 135
3.7.7 hprof 136
3.8 本章小結 138
第4章 大數(shù)據(jù)日志系統(tǒng)的構建 140
4.1 開源日志框架的原理分析與應用實踐 142
4.1.1 JDK Logger 142
4.1.2 Apache Commons Logging 143
4.1.3 Apache Log4j 147
4.1.4 Slf4j 156
4.1.5 Logback 160
4.1.6 Apache Log4j 2 164
4.2 日志系統(tǒng)的優(yōu)化和最佳實踐 168
4.2.1 開發(fā)人員的日志意識 168
4.2.2 日志級別的設置 168
4.2.3 日志的數(shù)量和大小 169
4.2.4 切割方式 170
4.2.5 日志格式的配置 170
4.2.6 一行日志導致的線上事故 177
4.3 大數(shù)據(jù)日志系統(tǒng)的原理與設計 178
4.3.1 通用架構和設計 179
4.3.2 日志采集器 180
4.3.3 日志緩沖隊列 186
4.3.4 日志解析器 187
4.3.5 日志存儲和搜索 187
4.3.6 日志展示系統(tǒng) 188
4.3.7 監(jiān)控和報警 188
4.3.8 日志系統(tǒng)的容量和性能評估 188
4.4 ELK系統(tǒng)的構建與使用 190
4.4.1 Elasticsearch 191
4.4.2 Logstash 193
4.4.3 Kibana 196
4.5 本章小結 198
第5章 基于調用鏈的服務治理系統(tǒng)的設計與實現(xiàn) 199
5.1 APM系統(tǒng)簡介 200
5.1.1 優(yōu)秀的開源APM系統(tǒng) 200
5.1.2 國內(nèi)商業(yè)APM產(chǎn)品的介紹 202
5.2 調用鏈跟蹤的原理 203
5.2.1 分布式系統(tǒng)的遠程調用過程 204
5.2.2 TraceID 207
5.2.3 SpanID 208
5.2.4 業(yè)務鏈 210
5.3 調用鏈跟蹤系統(tǒng)的設計與實現(xiàn) 211
5.3.1 整體架構 211
5.3.2 TraceID和SpanID在服務間的傳遞 213
5.3.3 采集器的設計與實現(xiàn) 217
5.3.4 處理器的設計與實現(xiàn) 222
5.3.5 調用鏈系統(tǒng)的展示 225
5.4 本章小結 226
第6章 Java服務的線上應急和技術攻關 227
6.1 海恩法則和墨菲定律 227
6.2 線上應急的目標、原則和方法 229
6.2.1 應急目標 229
6.2.2 應急原則 229
6.2.3 線上應急的方法和流程 230
6.3 技術攻關的方法論 233
6.4 環(huán)境搭建和示例服務啟動 236
6.5 高效的服務化治理腳本 240
6.5.1 show-busiest-java-threads 240
6.5.2 find-in-jar 243
6.5.3 grep-in-jar 244
6.5.4 jar-conflict-detect 245
6.5.5 http-spy 247
6.5.6 show-mysql-qps 248
6.5.7 小結 249
6.6 JVM提供的監(jiān)控命令 249
6.6.1 jad 249
6.6.2 btrace 250
6.6.3 jmap 252
6.6.4 jstat 255
6.6.5 jstack 256
6.6.6 jinfo 258
6.6.7 其他命令 258
6.6.8 小結 259
6.7 重要的Linux基礎命令 260
6.7.1 必不可少的基礎命令和工具 260
6.7.2 查看活動進程的命令 268
6.7.3 窺探內(nèi)存的命令 270
6.7.4 針對CPU使用情況的監(jiān)控命令 272
6.7.5 監(jiān)控磁盤I/O的命令 273
6.7.6 查看網(wǎng)絡信息和網(wǎng)絡監(jiān)控命令 275
6.7.7 Linux系統(tǒng)的高級工具 287
6.7.8 /proc文件系統(tǒng) 288
6.7.9 摘要命令 288
6.7.10 小結 290
6.8 現(xiàn)實中的應急和攻關案例 291
6.8.1 一次OOM事故的分析和定位 291
6.8.2 一次CPU 100%的線上事故排查 301
6.9 本章小結 304
第7章 服務的容器化過程 306
7.1 容器vs虛擬機 306
7.1.1 什么是虛擬機 306
7.1.2 什么是容器 306
7.1.3 容器和虛擬機的區(qū)別 307
7.1.4 容器主要解決的問題 307
7.1.5 Docker的優(yōu)勢 310
7.2 Docker實戰(zhàn) 311
7.2.1 Docker的架構 311
7.2.2 Docker的安裝 315
7.2.3 Docker初體驗 319
7.2.4 Docker后臺服務的管理 322
7.2.5 Docker的客戶端命令 328
7.2.6 Docker Compose編排工具的使用 372
7.3 容器化項目 379
7.3.1 傳統(tǒng)的應用部署 380
7.3.2 將應用程序部署在虛擬機上 380
7.3.3 容器化部署應用 381
7.3.4 Docker實現(xiàn)的應用容器化示例 382
7.4 本章小結 384
第8章 敏捷開發(fā)2.0的自動化工具 385
8.1 什么是敏捷開發(fā)2.0 385
8.1.1 常用的4種開發(fā)模式 385
8.1.2 什么是DevOps 390
8.1.3 敏捷開發(fā)2.0解決的問題 392
8.2 敏捷開發(fā)的自動化流程 393
8.2.1 持續(xù)集成 393
8.2.2 持續(xù)交付和持續(xù)部署 397
8.3 敏捷開發(fā)的常用自動化工具 400
8.3.1 分布式版本控制工具Git 400
8.3.2 持續(xù)集成和持續(xù)交付工具Jenkins 410
8.3.3 基礎平臺管理工具SaltStack 418
8.3.4 Docker容器化工具 421
8.4 本章小結 422
你還可能感興趣
我要評論
|