前言
第1章 微服務架構介紹1
1.1 微服務架構的齣現1
1.1.1 單體應用架構1
1.1.2 SOA架構2
1.1.3 微服務架構3
1.2 微服務架構的流派5
1.3 雲原生與微服務9
1.4 本章小結12
第2章 Spring Cloud總覽13
2.1 Spring Cloud架構13
2.2 Spring Cloud特性16
2.2.1 Spring Cloud Context:應用上下文16
2.2.2 Spring Cloud Commons:公共抽象19
2.3 本章小結21
第3章 Spring Cloud的基礎:Spring Boot22
3.1 Spring Boot簡介22
3.2 構建一個微服務24
3.3 Spring Boot配置文件29
3.3.1 默認配置文件29
3.3.2 外部化配置29
3.3.3 YAML30
3.3.4 自動載入外部屬性到Bean30
3.3.5 多Profile31
3.3.6 Starter32
3.3.7 自製一個Starter32
3.3.8 Actuator36
3.4 本章小結38
第4章 服務注冊與發現:Eureka39
4.1 基礎應用40
4.1.1 Eureka簡介40
4.1.2 搭建Eureka服務注冊中心40
4.1.3 搭建Eureka服務提供者42
4.1.4 搭建Eureka服務調用者43
4.1.5 Eureka服務注冊和發現44
4.1.6 Consul的簡單應用46
4.2 服務發現原理48
4.3 Eureka Client源碼解析49
4.3.1 讀取應用自身配置信息50
4.3.2 服務發現客戶端52
4.3.3 拉取注冊錶信息56
4.3.4 服務注冊61
4.3.5 初始化定時任務62
4.3.6 服務下綫68
4.4 Eureka Server源碼解析70
4.4.1 服務實例注冊錶70
4.4.2 服務注冊72
4.4.3 接受服務心跳74
4.4.4 服務剔除75
4.4.5 服務下綫77
4.4.6 集群同步78
4.4.7 獲取注冊錶中服務實例信息82
4.5 進階應用84
4.5.1 Eureka Instance和Client的元數據84
4.5.2 狀態頁和健康檢查頁端口設置85
4.5.3 區域與可用區85
4.5.4 高可用性服務注冊中心86
4.6 本章小結87
第5章 聲明式RESTful客戶端:Spring Cloud OpenFeign88
5.1 基礎應用88
5.1.1 微服務之間的交互88
5.1.2 OpenFeign簡介89
5.1.3 代碼示例89
5.2 源碼分析91
5.2.1 核心組件與概念91
5.2.2 動態注冊BeanDefinition92
5.2.3 實例初始化98
5.2.4 函數調用和網絡請求107
5.3 進階應用111
5.3.1 Decoder與Encoder的定製化111
5.3.2 請求/響應壓縮112
5.4 本章小結113
第6章 斷路器:Hystrix114
6.1 基礎應用114
6.1.1 RestTemplate與Hystrix115
6.1.2 OpenFeign與Hystrix117
6.2 Hystrix原理118
6.2.1 服務雪崩118
6.2.2 斷路器119
6.2.3 服務降級操作120
6.2.4 資源隔離121
6.2.5 Hystrix實現思路122
6.3 源碼解析123
6.3.1 封裝HystrixCommand123
6.3.2 HystrixCommand類結構129
6.3.3 異步迴調執行命令129
6.3.4 異步執行命令和同步執行命令137
6.3.5 斷路器邏輯137
6.3.6 資源隔離143
6.3.7 請求超時監控148
6.3.8 失敗迴滾邏輯150
6.4 進階應用152
6.4.1 異步與異步迴調執行命令152
6.4.2 繼承HystrixCommand153
6.4.3 請求閤並157
6.5 本章小結161
第7章 客戶端負載均衡器:Spring Cloud Netflix Ribbon162
7.1 負載均衡162
7.2 基礎應用163
7.3 源碼分析165
7.3.1 配置和實例初始化165
7.3.2 與OpenFeign的集成167
7.3.3 負載均衡器LoadBalancerClient171
7.3.4 ILoadBalancer173
7.3.5 負載均衡策略實現177
7.4 進階應用184
7.4.1 Ribbon API184
7.4.2 使用Netty發送網絡請求185
7.4.3 隻讀數據庫的負載均衡實現186
7.5 本章小結187
第8章 API網關:Spring Cloud Gateway189
8.1 Spring Cloud Gateway介紹189
8.2 基礎應用190
8.2.1 用戶服務191
8.2.2 網關服務192
8.2.3 客戶端的訪問195
8.3 源碼解析195
8.3.1 初始化配置196
8.3.2 網關處理器197
8.3.3 路由定義定位器202
8.3.4 路由定位器205
8.3.5 路由斷言208
8.3.6 網關過濾器216
8.3.7 全局過濾器227
8.3.8 API端點234
8.4 應用進階235
8.4.1 限流機製235
8.4.2 熔斷降級238
8.4.3 網關重試過濾器240
8.5 本章小結241
第9章 配置中心:Spring Cloud Config243
9.1 基礎應用244
9.1.1 配置客戶端244
9.1.2 配置倉庫245
9.1.3 服務端246
9.1.4 配置驗證248
9.1.5 配置動態更新249
9.2 源碼解析250
9.2.1 配置服務器251
9.2.2 配置客戶端261
9.3 應用進階267
9.3.1 為Config Server配置多個repo268
9.3.2 客戶端覆寫遠端的配置屬性268
9.3.3 屬性覆蓋269
9.3.4 安全保護269
9.3.5 加密解密270
9.3.6 快速響應失敗與重試機製272
9.4 本章小結272
第10章 消息驅動:Spring Cloud Stream274
10.1 消息隊列274
10.2 基礎應用276
10.2.1 聲明和綁定通道276
10.2.2 自定義通道276
10.2.3 接收消息276
10.2.4 配置278
10.3 源碼分析278
10.3.1 動態注冊BeanDefinition279
10.3.2 綁定服務282
10.3.3 獲取綁定器284
10.3.4 綁定生産者289
10.3.5 消息發送的流程291
10.3.6 StreamListener注解的處理293
10.3.7 綁定消費者298
10.3.8 消息的接收304
10.4 進階應用306
10.4.1 Bin
· · · · · · (
收起)