本書共分10章。
第1章介紹Nacos的動態發現、健康檢查、設定管理、技術選型、分散式事務及其與Eureka的區別。
第2章介紹Dubbo的基本概念、整合、設定、註冊中心、偵錯和監控、擴充、原理、性能最佳化及序列化協定。
第3章介紹ZooKeeper的結構、特性、資料模型、API、應用場景、工作原理以及監控和管理。
第4章介紹Spring Cloud Security OAuth 2的授權模式、底層工作原理及JWT技術。
第5章介紹Spring Cloud Gateway的路由與更新、負載平衡策略、篩檢程式、限流方式、底層工作原理及高併發下的問題與解決方案。
第6章介紹分散式鏈路追蹤的背景和概念,Skywalking的安裝設定、資料獲取、呼叫堆疊分析和故障排除。
第7章介紹量控制元件,涵蓋限流、熔斷、降級、動態規則、服務治理、流量控制方式、核心元件及Sentinel規則和持久化推送模式。
第8章介紹了Apache ShardingSphere與同類產品,並討論分片策略、資料遮罩、分散式事務、資料庫讀寫分離、主從同步、叢集管理、跨資料庫分頁、垂直與水平拆分、廣播與綁定資料表及底層實現原理。
第9章介紹Elasticsearch、Logstash和Kibana的安裝設定及底層實現原理。
第10章介紹RocketMQ的安裝、設定、架構、基本原理及高可用性、容錯性、性能優化和監控方法。
【本書看點】
●動態發現與健康檢查
●Dubbo基本概念與整合
●ZooKeeper結構與特性
●OAuth 2授權模式
●Spring Cloud Gateway路由與更新
●分散式鏈路追蹤背景和概念
●流量控制元件對比介紹
●ShardingSphere分片策略與資料遮罩
●Elasticsearch+Logstash+Kibana安裝設定
●RocketMQ架構與基本原理
作者簡介:
廖志偉
Java開發者、Java領域優質創作者、CSDN知名博客專家、51CTO專家博主、阿里雲專家博主。擁有多年一線研發和團隊管理經驗,主要研究主流框架的底層源碼(Spring、Spring Boot、Spring MVC、Spring Could、MyBatis、Dubbo、ZooKeeper)、消息中間件底層架構原理(RabbitMQ、RockerMQ、Kafka)、Redis緩存、MySQL關係資料庫、Elasticsearch全文搜索、MongoDB非關係資料庫、Apache ShardingSphere分庫分表讀寫分離、設計模式、領域驅動DDD、Kubernetes等。長期堅持撰寫技術博客,目前主要活躍在CSDN博客社區。
作者序
為了滿足各種不同類型應用的需求,Java 開發工程師需要熟練掌握多種技術。這些技術涉及的技術堆疊較多,需要花費大量的時間和精力進行深入學習和應用。開發人員需要具備極大的耐心和毅力來克服這些技術學習和應用中存在的挑戰。然而,其中一些技術的通用性並不高,各家公司使用的技術方案也不盡相同,這導致開發人員深入研究一門技術後,發現在其他公司可能並不適用,因此需要重新學習和研究其他技術。
透過市場調研,筆者發現Spring Cloud Alibaba Nacos、Dubbo、ZooKeeper、Spring Cloud Security OAuth 2、Spring Cloud Gateway、Spring Cloud Skywalking、Spring Cloud Alibaba Sentinel、Apache ShardingSphere、Elasticsearch+Logstash+Kibana 和RocketMQ 等技術具有流通性和通用性。這些技術在開放原始碼社區中已趨成熟並得到廣泛使用,擁有較大的開發者社區和使用者基礎。同時,這些技術在相應領域內具有完整的功能,能夠滿足開發者在專案中的多種需求。這些技術在長期的實踐和最佳化過程中,已經得到廣泛驗證,因此具有較高的可靠性和穩定性。此外,這些技術都提供了友善的文件和範例,易於開發者快速上手和使用。
本書的目的在於深入底層,了解技術的實現原理、使用方法和應用場景,幫助讀者更進一步地理解技術的實際應用。本書透過豐富的案例、故事情節和實戰經驗等,將諸多通用性較高的技術進行深入講解。透過撰寫本書,筆者查閱了大量資料,擴大了自身的知識系統,並從中獲得了很多有益的收穫。
本書主要內容
第1 章介紹Nacos 的動態發現、健康檢查、設定管理、技術選型、分散式事務、與Eureka 的區別、底層實現原理和實戰應用。
第2 章介紹Dubbo 的基本概念、整合、設定、註冊中心、偵錯和監控、擴充、原理、性能最佳化及序列化協定、手寫Dubbo 框架。
第3 章介紹ZooKeeper 的結構、特性、資料模型、API、應用場景、工作原理、監控和管理。
第4 章介紹Spring Cloud Security OAuth 2 的授權模式、底層工作原理及JWT 技術。
第5 章介紹Spring Cloud Gateway 路由與更新、負載平衡策略、篩檢程式、限流方式、底層工作原理、高併發下的問題及解決方案。
第6 章介紹分散式鏈路追蹤的背景和概念、Skywalking 的安裝設定、資料獲取的方式和邏輯、呼叫堆疊分析和故障排除。
第7 章介紹流量控制元件對比介紹、限流/ 熔斷/ 降級、動態規則/ 服務治理、流量控制方式、核心元件、Sentinel 的4 種規則,持久化推送模式。
第8 章介紹Apache ShardingSphere 同類產品對比、分片策略、資料遮罩、分散式事務、資料庫讀寫分離、資料庫主從同步、資料庫叢集管理、跨資料庫分頁、垂直拆分和水平拆分、廣播資料表與綁定資料表及底層實現原理。
第9 章介紹Elasticsearch+Logstash+Kibana 的安裝與設定,以及底層實現原理。
第10 章介紹RocketMQ 的安裝、設定、架構、基本原理及相關的高可用性、容錯性、性能調優、監控方法。
閱讀建議
本書是一本綜合性書籍,涵蓋了基礎、進階和實戰應用的內容。書中既包含深入的底層基礎知識,也有生動的故事情節和案例分析,同時提供了詳細的程式範例。本書對技術描述非常詳細,還提供了適合入門讀者的程式註釋,幫助讀者理解內容並提升信心,輕鬆掌握底層工作原理並快速進入實戰。
閱讀前,快速瀏覽目錄和章節概覽可幫助了解書籍結構、內容和重點。了解自己希望從中獲得什麼樣的知識或經驗可以指導閱讀和吸收資訊。建議在閱讀時做筆記、思考問題、自我提問,以加深理解和吸收知識。閱讀結束後,反思和總結所學內容,並嘗試應用到現實生活中,有助深化理解和應用知識。與朋友或同事分享所讀內容,討論細節並獲得回饋,也有助加深對知識的理解和吸收。
致謝
本書的完成離不開許多人的幫助和支援。在此,我要向那些給予我幫助的人們表示真摯的感謝。
衷心感謝讀者對本書的支援和關注,同時歡迎對本書提出建議和意見,筆者會認真聽取並持續改進。
廖志偉
為了滿足各種不同類型應用的需求,Java 開發工程師需要熟練掌握多種技術。這些技術涉及的技術堆疊較多,需要花費大量的時間和精力進行深入學習和應用。開發人員需要具備極大的耐心和毅力來克服這些技術學習和應用中存在的挑戰。然而,其中一些技術的通用性並不高,各家公司使用的技術方案也不盡相同,這導致開發人員深入研究一門技術後,發現在其他公司可能並不適用,因此需要重新學習和研究其他技術。
透過市場調研,筆者發現Spring Cloud Alibaba Nacos、Dubbo、ZooKeeper、Spring Cloud Security OAuth 2、Spring Cloud Gateway、Spri...
目錄
第1章 Spring Cloud Alibaba Nacos
1.1 動態發現/ 健康檢查/ 設定管理
1.2 服務治理的技術選型
1.3 分散式事務CAP 理論
1.4 Eureka 與Nacos 的區別
1.5 底層實現原理
1.6 實戰應用
第2章 Dubbo
2.1 Dubbo 的基本概念
2.2 Dubbo 與Spring Boot 的整合
2.3 Dubbo 的設定方式
2.4 Dubbo 的註冊中心架構和各種註冊中心的特點
2.5 Dubbo 的偵錯和監控
2.6 Dubbo 的擴充點
2.7 Dubbo 的原理
2.8 Dubbo 的性能最佳化
2.9 Dubbo 的序列化協定
2.10 手寫一個Dubbo 框架
第3章 ZooKeeper
3.1 ZooKeeper 概述
3.2 Docker 環境下安裝與設定ZooKeeper
3.3 ZooKeeper 特性
3.4 ZooKeeper 資料模型
3.5 ZooKeeper API
3.6 ZooKeeper 應用場景
3.7 ZooKeeper 工作原理
3.8 ZooKeeper 的監控和管理
3.9 高併發環境下ZooKeeper 可能會出現的問題
第4章 Spring Cloud Security OAuth 2
4.1 授權模式
4.2 底層工作原理
4.3 JWT
第5章 Spring Cloud Gateway
5.1 動態路由/ 限流/ 負載平衡
5.2 閘道產品對比
5.3 路由與更新
5.4 負載平衡策略
5.5 篩檢程式
5.6 限流方式
5.7 底層工作原理
5.8 高併發下Spring Cloud Gateway 的問題及解決方案
第6章 Spring Cloud Skywalking
6.1 分散式鏈路追蹤的背景和概念
6.2 Docker 環境下Skywalking 的安裝與設定
6.3 分散式鏈路追蹤實現
6.4 Skywalking 架構和元件
6.5 資料獲取的方式和邏輯
6.6 鏈路追蹤資料模型
6.7 呼叫堆疊分析和故障排除
6.8 自訂指標的收集和分析
6.9 靜態設定和動態設定的實現原理
6.10 安全性和許可權管理
6.11 網路通訊延遲時間和傳輸損耗的影響
6.12 最佳化方案
第7章 Spring Cloud Alibaba Sentinel
7.1 流量控制元件對比介紹
7.2 限流/ 熔斷/ 降級
7.3 動態規則/ 服務治理
7.4 流量控制方式
7.5 核心元件
7.6 Sentinel 的4 種規則
7.7 持久化推送模式
第8章 Apache ShardingSphere
8.1 同類產品對比介紹
8.2 分片策略
8.3 資料遮罩
8.4 分散式事務
8.5 資料庫讀寫分離
8.6 資料庫主從同步
8.7 資料庫叢集管理
8.8 跨資料庫分頁
8.9 垂直拆分和水平拆分
8.10 廣播資料表和綁定資料表
8.11 底層實現原理
第9章 Elasticsearch+Logstash+Kibana
9.1 ELK 的介紹
9.2 ELK 的安裝與設定
9.3 底層實現原理
第10章 RocketMQ
10.1 RocketMQ 安裝與設定
10.2 RocketMQ 的架構和基本原理
10.3 Producer 和Consumer 模型、發送和接收訊息
10.4 訊息儲存機制和訊息佇列的分散式特性
10.5 訊息訂閱模式和消費者模式
10.6 訊息過濾機制和訊息重試機制
10.7 事務訊息和順序訊息
10.8 高可用性和容錯性設計
10.9 訊息軌跡功能
10.10 身份驗證和安全機制
10.11 性能調優
第1章 Spring Cloud Alibaba Nacos
1.1 動態發現/ 健康檢查/ 設定管理
1.2 服務治理的技術選型
1.3 分散式事務CAP 理論
1.4 Eureka 與Nacos 的區別
1.5 底層實現原理
1.6 實戰應用
第2章 Dubbo
2.1 Dubbo 的基本概念
2.2 Dubbo 與Spring Boot 的整合
2.3 Dubbo 的設定方式
2.4 Dubbo 的註冊中心架構和各種註冊中心的特點
2.5 Dubbo 的偵錯和監控
2.6 Dubbo 的擴充點
2.7 Dubbo 的原理
2.8 Dubbo 的性能最佳化
2.9 Dubbo 的序列化協定
2.10 手寫一個Dubbo 框架
第3章 ZooKeeper
3.1 ZooKeeper 概述
3.2 Docker...