本書從架構設計、應用開發和運維部署三個方麵齣發,對微服務架構設計的實施進行瞭全方位的闡述和深入實踐,並結閤生産實際講解瞭Spring Cloud、Docker和Jenkins等工具的具體使用方法。書中通過一個互聯網電商平颱實例實現瞭高並發的微服務架構設計,並通過詳細的開發和實施過程,演示瞭構建一個安全可靠、穩定高效並可持續擴展的係統平颱的方法。本書適閤互聯網應用開發設計人員參考學習。
陳韶健,資深IT技術專傢,著有《深入實踐Spring Boot》(2016年10月機械工業齣版社)、《Neo4j全棧開發》(2017年6月電子工業齣版社)等書籍,在虛擬化技術領域、數據庫使用和大數據分析、分布式架構設計、Spring等開源框架使用、微服務實施和開發等領域都有深入的研究和豐富的實踐經驗。未來研究方嚮:物聯網、智慧城市、AI人工智能等。
第一部分 架 構 篇
1 微服務架構與Spring Cloud 2
1.1 微服務概念的由來 2
1.2 微服務的定義 3
1.3 微服務架構與整體式架構的區彆 5
1.4 微服務架構與SOA的比較 8
1.5 為什麼要使用微服務架構 9
1.6 為實施微服務架構做好準備 10
1.6.1 思想觀念的轉變 10
1.6.2 團隊管理方式的改變 11
1.6.3 自動化基礎設施的建設 11
1.7 為什麼要使用Spring Cloud 12
1.8 Spring Cloud組件介紹 13
1.9 Spring Cloud的版本說明 15
1.10 小結 17
2 微服務架構最佳設計 18
2.1 閤理劃分微服務 19
2.2 微服務治理 19
2.3 Rest API微服務設計 21
2.3.1 使用數據庫集群 22
2.3.2 讀寫分離設計 22
2.3.3 使用緩存 22
2.3.4 保證Rest API微服務的獨立性 23
2.4 Web UI微服務設計 23
2.4.1 使用FeignClient實現負載均衡調用 23
2.4.2 使用Hystrix實現容錯設計 23
2.4.3 使用非阻塞的異步編程技術實現高並發調用 24
2.4.4 使用分布式文件係統 24
2.5 微服務之間調用規則設計 24
2.6 數據最終一緻性設計 25
2.7 分布式集群架構設計 26
2.8 微服務運行環境安全設計 27
2.9 小結 27
3 電商平颱微服務設計實例 29
3.1 電商平颱總體設計 29
3.1.1 總體業務流程設計 29
3.1.2 總體業務功能設計 31
3.2 電商平颱業務模型設計 32
3.2.1 移動商城業務模型 32
3.2.2 商傢管理後颱業務模型 33
3.2.3 平颱管理後颱業務模型 33
3.3 創建Rest API微服務 34
3.4 創建Web UI微服務 36
3.4.1 移動商城Web UI微服務 36
3.4.2 商傢管理後颱的Web UI微服務 37
3.4.3 平颱管理後颱Web UI微服務 37
3.5 電商平颱微服務體係結構 38
3.6 小結 39
第二部分 開 發 篇
4 開發工具選用及Spring Boot基礎 41
4.1 開發工具選擇 42
4.2 開發環境配置 42
4.3 創建Spring Boot工程 43
4.4 使用JPA 47
4.4.1 數據源配置 48
4.4.2 JPA配置 48
4.4.3 數據實體設計 49
4.4.4 存儲庫接口設計 49
4.4.5 單元測試 50
4.5 使用Thymeleaf 51
4.5.1 控製器設計 51
4.5.2 視圖設計 52
4.6 運行與部署 52
4.7 小結 53
5 電商平颱微服務工程設計 54
5.1 微服務工程結構 54
5.2 電商平颱微服務工程組建 56
5.3 數據庫選型 56
5.4 微服務工程創建步驟 57
5.5 項目基本配置 59
5.6 創建模塊 63
5.7 小結 65
6 微服務治理基礎服務開發 66
6.1 注冊管理中心 67
6.1.1 創建注冊管理中心 67
6.1.2 運行注冊管理中心 69
6.1.3 微服務怎樣使用注冊管理中心 69
6.1.4 構建高可用的注冊管理中心 71
6.2 配置管理中心 72
6.2.1 創建配置管理中心 72
6.2.2 微服務如何使用配置管理中心 75
6.2.3 在綫更新配置信息 76
6.3 微服務監控中心 77
6.3.1 使用斷路器儀錶盤實現監控 78
6.3.2 聚閤服務監控管理中心 80
6.4 服務跟蹤分析中心 85
6.4.1 創建服務跟蹤分析中心 85
6.4.2 在微服務中啓用服務跟蹤功能 89
6.5 日誌分析平颱 92
6.5.1 創建日誌分析平颱 92
6.5.2 使用日誌分析平颱 92
6.6 小結 93
7 Rest API微服務開發 95
7.1 領域業務開發 95
7.1.1 使用Druid數據源 97
7.1.2 JPA及其配置 99
7.1.3 數據實體建模 100
7.1.4 查詢對象設計 103
7.1.5 實體持久化設計 105
7.1.6 持久化測試 106
7.1.7 領域服務開發 108
7.1.8 領域服務的單元測試 110
7.1.9 使用Redis實現緩存設計 111
7.2 Rest API應用開發 116
7.2.1 Rest API應用配置 116
7.2.2 啓動程序設計 118
7.2.3 接口開發 118
7.3 使用消息處理事件 122
7.3.1 消息生産者設計 123
7.3.2 消息消費者設計 124
7.3.3 使用消息測試 127
7.4 小結 128
8 Web UI微服務開發 130
8.1 高並發接口調用分層設計 130
8.2 通過FeignClient調用Rest API 131
8.3 使用Hystrix斷路器 133
8.4 使用非阻塞異步編程方法 135
8.4.1 CompletableFuture介紹 136
8.4.2 性能比較測試 139
8.5 Web應用開發 144
8.5.1 項目引用配置 144
8.5.2 應用程序配置 145
8.5.3 業務功能開發 147
8.6 開發環境的熱部署設置 153
8.7 使用分布式文件係統 156
8.7.1 分布式文件係統客戶端開發 156
8.7.2 商品圖片上傳設計 158
8.7.3 富文本編輯器上傳文件設計 159
8.7.4 建立本地文件信息庫 162
8.8 小結 165
9 電商平颱移動商城開發 166
9.1 移動商城首頁設計 167
9.2 使用負載均衡的導航設計 173
9.3 按分類查詢設計 175
9.4 商品詳情頁設計 178
9.5 購買下單實現 180
9.6 用戶登錄與賬戶切換設計 183
9.6.1 用戶登錄設計 183
9.6.2 切換賬號設計 185
9.7 訂單查詢設計 187
9.8 集成測試 190
9.9 小結 191
10 商傢管理後颱與SSO設計 192
10.1 商傢權限管理體係設計及開發 193
10.1.1 商傢權限體係建模 194
10.1.2 商傢權限體係的持久化設計 198
10.1.3 商傢權限體係的領域服務開發 200
10.2 商傢管理微服務開發 203
10.2.1 商傢領域服務層單元測試 203
10.2.2 商傢服務的接口開發 207
10.3 SSO設計 212
10.3.1 SSO基本配置 212
10.3.2 在SSO中使用商傢的權限體係 213
10.3.3 用戶登錄設計 215
10.3.4 有關驗證碼的說明 217
10.3.5 SSO的主頁設計 219
10.3.6 OAuth2服務端設計 221
10.4 SSO客戶端設計 223
10.4.1 客戶端的項目管理配置 223
10.4.2 客戶端的安全管理配置 224
10.4.3 權限驗證實現原理 225
10.4.4 如何在應用中接入SSO 227
10.4.5 有關跨站請求僞造防禦的相關設置 229
10.4.6 根據用戶權限自動分配菜單 229
10.5 小結 231
11 平颱管理後颱開發 232
11.1 平颱管理後颱領域設計 232
11.1.1 領域實體建模 232
11.1.2 實體的行為設計 235
11.1.3 領域服務開發 235
11.1.4 領域服務單元測試 238
11.2 平颱管理後颱訪問控製設計 239
11.2.1 使用平颱管理的用戶體係 239
11.2.2 權限管理設計 241
11.3 商傢的注冊設計 244
11.4 商傢菜單體係管理開發 247
11.4.1 分類菜單管理開發 247
11.4.2 模塊菜單管理開發 248
11.4.3 訪問資源管理開發 251
11.5 商傢角色管理開發 254
11.6 小結 256
第三部分 運 維 篇
12 服務器架構設計與Docker使用 258
12.1 服務器組建 258
12.2 安全的服務器架構設計 259
12.2.1 防火牆安裝及配置 259
12.2.2 建立安全的局域網環境 263
12.3 服務器資源分配 265
12.4 CentOS安裝 268
12.4.1 IP地址設置 269
12.4.2 安全設置 269
12.4.3 語言配置 269
12.4.4 時間同步配置 270
12.5 Docker和docker-compose安裝 270
12.5.1 Docker安裝及使用 271
12.5.2 docker-compose安裝及使用 274
12.6 使用Docker搭建微服務治理環境 278
12.6.1 服務器1的部署配置 278
12.6.2 服務器2的部署配置 280
12.7 使用Docker部署日誌分析平颱 282
12.8 使用Docker部署微服務應用 285
12.9 小結 285
13 數據庫集群設計與高可用讀寫分離實施 287
13.1 MySQL安裝 288
13.2 主從同步設置 290
13.3 主主同步設置 293
13.4 數據庫代理中間件選擇 295
13.5 使用OneProxy實現讀寫分離設計 296
13.5.1 OneProxy安裝 296
13.5.2 高可用讀寫分離配置 297
13.6 OneProxy分庫分區設計 301
13.6.1 按範圍分庫分錶 302
13.6.2 按值分庫分錶 302
13.6.3 按哈希算法分庫分錶 303
评分
评分
评分
评分
评分
评分
评分
评分
本站所有內容均為互聯網搜索引擎提供的公開搜索信息,本站不存儲任何數據與內容,任何內容與數據均與本站無關,如有需要請聯繫相關搜索引擎包括但不限於百度,google,bing,sogou 等
© 2025 tushu.tinynews.org All Rights Reserved. 求知書站 版权所有