微服務(wù)分布式架構(gòu)基礎(chǔ)與實戰(zhàn)——基于Spring Boot + Spring Cloud
定 價:59 元
- 作者:張方興
- 出版時間:2020/3/1
- ISBN:9787121384134
- 出 版 社:電子工業(yè)出版社
- 中圖法分類:TP368.5
- 頁碼:272
- 紙張:膠版紙
- 版次:01
- 開本:16K
微服務(wù)分布式架構(gòu)的內(nèi)容更新迭代速度極快,2018年6月開始就有許多微服務(wù)分布式的數(shù)據(jù),但是到2019年已經(jīng)跟不上Spring Cloud的版本了,過去大多數(shù)數(shù)據(jù)Spring Cloud都用Eureka作為注冊中心,而Spring 官方已經(jīng)在Spring Cloud Eureka 2.0以后宣布停止了Spring Cloud Eureka的更新計劃,廢棄該項目并將Consul作為Spring Cloud的注冊中心。另外大多數(shù)書籍的網(wǎng)關(guān)依舊使用的Spring Cloud Zuul,但是目前Spring 已經(jīng)逐漸廢棄Spring Cloud Zuul,而是讓Spring Cloud Gateway接替他的網(wǎng)關(guān)位置。市面上的同類書的技術(shù)將沒有將此內(nèi)容更新。另外本書從分布式架構(gòu)程序的方式角度進行講解,包括分布式任務(wù)調(diào)度、分布式事務(wù)管理,重點提及了這部分的實戰(zhàn)與思想。很多書只是用來教導框架構(gòu)架,而本書則希望通過框架讓讀者認識分布式的具體操作方法。本書以案例任務(wù)模式主要介紹了Spring Boot微服務(wù)的持久化、緩存、緩存同步、隊列,Spring Cloud的新版注冊中心Consul、新版網(wǎng)關(guān)Spring Cloud Gateway、Spring Cloud分布式通訊、共享信息、單點登錄、鑒權(quán)等相關(guān)內(nèi)容。
張方興,多年從事Java編程工作,參與多個項目的研發(fā)工作,精通Java編程與SSM技術(shù)。
第1章 微服務(wù)分布式架構(gòu)設(shè)計原理 1
1.1 Java Web應(yīng)用程序的發(fā)展歷史 1
1.2 微服務(wù)分布式 2
1.2.1 Spring Boot微服務(wù)的定義和特點 3
1.2.2 Spring Boot的職場導讀 3
1.2.3 Spring部分內(nèi)容 4
1.2.4 微服務(wù)的拆分 6
1.3 【實例】微服務(wù)工程Hello World 7
1.3.1 實例背景 7
1.3.2 創(chuàng)建Maven Project 7
1.3.3 使用空Maven Project模板 7
1.3.4 編輯Maven坐標定位及工程名 8
1.3.5 檢查Maven目錄結(jié)構(gòu) 9
1.3.6 編寫Pom文件 10
1.3.7 Spring Boot依賴包的導入 12
1.3.8 編寫Spring Boot啟動類 14
1.3.9 編寫Spring Boot接口 14
1.3.10 當前項目結(jié)構(gòu) 14
1.3.11 啟動工程 15
1.3.12 Spring Boot初始化啟動后 16
1.3.13 實例易錯點 16
1.4 Spring Boot啟動類掃描Bean 18
1.4.1 @SpringBootApplication注解 18
1.4.2 @ComponentScan注解 20
1.4.3 Spring Boot掃描其他包下文件 20
1.5 【實例】將端口號改成9090 21
1.5.1 實例背景 21
1.5.2 創(chuàng)建application.properties資源配置
文件 22
1.5.3 增加資源配置文件中的配置信息 23
1.5.4 運行結(jié)果 23
1.5.5 實例易錯點 23
1.6 YAML文件 24
1.6.1 YAML文件簡介 25
1.6.2 YAML文件的書寫格式 25
1.7 【實例】使用YAML配置文件 25
1.7.1 實例背景 25
1.7.2 原properties文件 25
1.7.3 轉(zhuǎn)換格式后的YAML文件 26
1.7.4 實例易錯點 26
1.8 【實例】通過單配置文件讓工程
適應(yīng)多應(yīng)用場景 27
1.8.1 實例背景 27
1.8.2 更改application.yml文件 27
1.8.3 更改啟動類 27
1.8.4 輸入啟動參數(shù) 29
1.8.5 運行結(jié)果 30
1.8.6 實例易錯點 30
1.9 【實例】通過多配置文件使工程
適應(yīng)多應(yīng)用場景 31
1.9.1 實例背景 31
1.9.2 新建SIT和UAT環(huán)境所需資源
配置文件 31
1.9.3 新建系統(tǒng)資源配置文件 31
1.9.4 編寫啟動類 31
1.9.5 當前項目結(jié)構(gòu) 32
1.9.6 運行結(jié)果 32
1.10 微服務(wù)配置權(quán)重 32
1.10.1 資源配置信息類型的權(quán)重 32
1.10.2 資源配置文件類型的權(quán)重 33
1.10.3 資源配置文件存在位置與權(quán)重
解讀 33
1.11 本章小結(jié) 34
1.12 習題 34
第2章 分布式的注冊中心 35
2.1 注冊中心 35
2.1.1 Eureka與Consul的區(qū)別 35
2.1.2 Consul的相關(guān)術(shù)語 37
2.1.3 Consul的安裝 37
2.2 Consul的常用命令 37
2.2.1 consul agent -dev 38
2.2.2 consul -members 39
2.2.3 consul leave 40
2.2.4 agent命令的常用配置參數(shù) 40
2.2.5 HTTP API 41
2.3 【實例】創(chuàng)建第一個微服務(wù)分布式
項目 42
2.3.1 實例背景 42
2.3.2 搭建Consul集群 42
2.3.3 創(chuàng)建微服務(wù)工程編寫相應(yīng)依賴
文件 45
2.3.4 Spring Cloud和Spring Boot的
版本對應(yīng)關(guān)系 46
2.3.5 編寫微服務(wù)YAML資源配置文件 46
2.3.6 編寫微服務(wù)啟動類注冊到
Consul上 48
2.3.7 當前項目結(jié)構(gòu) 48
2.3.8 運行結(jié)果 49
2.3.9 實例易錯點 50
2.4 【實例】通過代碼獲取Consul中的
服務(wù)信息 51
2.4.1 實例背景 51
2.4 2 編寫獲得其他注冊服務(wù)的代碼 52
2.4 3 運行結(jié)果 53
2.4.4 實例易錯點 53
2.5 【實例】Spring Cloud操作Consul
的K/V存儲 54
2.5.1 實例背景 54
2.5.2 添加依賴 54
2.5.3 利用Consul的UI界面添加K/V
存儲 54
2.5.4 編寫YAML資源配置文件對應(yīng)
K/V存儲 55
2.5.5 編寫MyConfig.java文件對應(yīng)
相關(guān)K/V存儲 56
2.5.6 調(diào)用MyConfig.java中的參數(shù) 57
2.5.7 在啟動類引用相關(guān)配置 57
2.5.8 當前項目結(jié)構(gòu) 58
2.5.9 運行結(jié)果 58
2.5.10 實例易錯點 60
2.6 本章小結(jié) 60
2.7 習題 60
第3章 分布式的通信 61
3.1 分布式通信 61
3.1.1 Spring Cloud Feign 61
3.1.2 Swagger 61
3.2 【實例】微服務(wù)集成Swagger 62
3.2.1 實例背景 62
3.2.2 編寫Swagger依賴 62
3.2.3 編寫Swagger配置 63
3.2.4 編寫接口與接口處的Swagger
配置 64
3.2.5 當前項目結(jié)構(gòu) 66
3.2.6 運行效果 66
3.2.7 實例易錯點 70
3.3 【實例】Feign調(diào)用微服務(wù)接口 72
3.3.1 實例背景 72
3.3.2 引入相關(guān)配置信息 73
3.3.3 編寫Feign客戶端 73
3.3.4 編寫調(diào)用 75
3.3.5 編寫啟動類 76
3.3.6 當前項目結(jié)構(gòu) 76
3.3.7 運行結(jié)果 77
3.3.8 實例易錯點 77
3.4 【實例】Feign的攔截器 78
3.4.1 實例背景 78
3.4.2 在cloud-admin-8084工程中增加
攔截器 78
3.4.3 當前項目結(jié)構(gòu) 79
3.4.4 運行結(jié)果 79
3.4.5 實例易錯點 80
3.5 Feign的配置 81
3.5.1 傳輸數(shù)據(jù)壓縮配置 81
3.5.2 日志配置 82
3.5.3 超時配置 83
3.6 【實例】Feign的降級回退處理
——Feign的Fallback類 84
3.6.1 實例背景 84
3.6.2 在資源配置文件中開啟Feign內(nèi)置
的Hystrix權(quán)限 84
3.6.3 編寫Fallback降級類 84
3.6.4 Service整合Fallback降級類 84
3.6.5 當前項目結(jié)構(gòu) 85
3.6.6 運行結(jié)果 85
3.7 【實例】Feign的降級回退處理
——Feign的Fallback工廠 86
3.7.1 實例背景 86
3.7.2 編寫Fallback降級工廠 86
3.7.3 整合Fallback降級工廠 87
3.7.4 實例易錯點 87
3.8 本章小結(jié) 88
3.9 習題 88
第4章 分布式的客戶端負載均衡 89
4.1 負載均衡 89
4.1.1 傳統(tǒng)服務(wù)器端負載均衡 89
4.1.2 Ribbon客戶端負載均衡 89
4.2 【實例】Feign整合Ribbon分發(fā)
請求 90
4.2.1 實例背景 90
4.2.2 編寫cloud-book-8086啟動類與
配置類支持Ribbon 91
4.2.3 Service和Controller 92
4.2.4 當前項目結(jié)構(gòu) 94
4.2.5 運行效果 95
4.2.6 實例易錯點 96
4.3 Ribbon的負載均衡策略配置 97
4.4 本章小結(jié) 98
4.5 習題 98
第5章 分布式的斷路器 99
5.1 斷路器 99
5.1.1 為什么需要斷路器 99
5.1.2 Hystrix 99
5.1.3 Hystrix解決的問題 100
5.1.4 Hystrix如何解決問題 100
5.2 【實例】Hystrix斷路器的降級
回退 101
5.2.1 實例背景 101
5.2.2 編寫相關(guān)Pom文件 101
5.2.3 編寫application資源配置文件 101
5.2.4 編寫Ribbon配置類 102
5.2.5 編寫啟動類 102
5.2.6 編寫Service類 103
5.2.7 編寫Controller類 103
5.2.8 當前項目結(jié)構(gòu) 104
5.2.9 運行結(jié)果 105
5.2.10 實例易錯點 106
5.3 Hystrix線程池 108
5.3.1 Hystrix斷路器注解式的命令
配置 109
5.3.2 Hystrix斷路器的注解式線程池
配置 111
5.3.3 Hystrix斷路器注解式的整體
定制配置 112
5.3.4 Hystrix斷路器資源配置式的
整體定制配置 113
5.4 【實例】Hystrix斷路器的請求
緩存 114
5.4.1 實例背景 114
5.4.2 通過Filter初始化Hystrix
上下文 114
5.4.3 讓啟動類掃描Filter過濾器 116
5.4.4 編寫Controller的Helper類 116
5.4.5 編寫Controller類 118
5.4.6 當前項目結(jié)構(gòu) 118
5.4.7 運行結(jié)果 119
5.4.8 銷毀Hystrix的請求緩存 121
5.4.9 實例易錯點 121
5.5 【實例】Hystrix的請求合并 123
5.5.1 實例背景 123
5.5.2 增加@HystrixCollapser請求合并
修飾的函數(shù) 124
5.5.3 Controller中調(diào)用請求合并函數(shù) 126
5.5.4 當前項目結(jié)構(gòu) 126
5.5.5 運行結(jié)果 127
5.5.6 實例易錯點 128
5.6 【實例】Hystrix的可視化監(jiān)控 129
5.6.1 實例背景 129
5.6.2 Hystrix可視化監(jiān)控的依賴 129
5.6.3 Hystrix可視化監(jiān)控的啟動類 129
5.6.4 被監(jiān)控的微服務(wù)增加響應(yīng)地址 130
5.6.5 當前項目結(jié)構(gòu) 131
5.6.6 運行結(jié)果 132
5.6.7 實例易錯點 134
5.7 本章小結(jié) 135
5.8 習題 135
第6章 微服務(wù)的異步線程池 136
6.1 異步線程池 136
6.1.1 異步線程池特點 136
6.1.2 常見的線程池 136
6.2 【實例】創(chuàng)建無返回值異步線
程池 137
6.2.1 實例背景 137
6.2.2 編寫Pom文件 137
6.2.3 編寫Spring Boot啟動類 138
6.2.4 編寫異步線程池任務(wù)接口與
實現(xiàn) 138
6.2.5 編寫外部可調(diào)用接口 139
6.2.6 當前項目結(jié)構(gòu) 140
6.2.7 運行程序查看異步線程池效果 140
6.2.8 實例易錯點 141
6.3 【實例】創(chuàng)建有返回值異步
線程池 141
6.3.1 實例背景 141
6.3.2 增加新的服務(wù)接口 141
6.3.3 增加新的服務(wù)實現(xiàn) 141
6.3.4 增加新的調(diào)用 142
6.3.5 當前項目結(jié)構(gòu) 142
6.3.6 運行程序查看異步線程池效果 142
6.3.7 實例易錯點 143
6.4 【實例】優(yōu)化異步線程池 143
6.4.1 實例背景 143
6.4.2 創(chuàng)建初始化線程池配置類 143
6.4.3 更改無返回值的異步線程池
Service實現(xiàn)類 145
6.4.4 運行程序查看異步線程池效果 145
6.4.5 實例易錯點 146
6.5 【實例】優(yōu)雅停止異步線程池 146
6.5.1 實例背景 146
6.5.2 何為“優(yōu)雅” 146
6.5.3 修改原Config配置類 147
6.5.4 修改原Controller控制層 148
6.5.5 當前項目結(jié)構(gòu) 149
6.5.6 優(yōu)雅停止異步線程池的執(zhí)行
效果 150
6.5.7 實例易錯點 152
6.6 @Enable*注解 152
6.7 本章小結(jié) 152
6.8 習題 153
第7章 微服務(wù)整合持久化數(shù)據(jù)源 154
7.1 spring-data 154
7.1.1 ORM規(guī)范 154
7.1.2 JPA、Hibernate、spring-data-jpa
之間的關(guān)系 155
7.1.3 安裝MySQL 155
7.2 【實例】Spring Boot整合MyBaits
注解式編程 156
7.2.1 實例背景 156
7.2.2 添加Pom文件 156
7.2.3 編寫application資源配置文件 157
7.2.4 編寫dao層 157
7.2.5 編寫訪問接口 159
7.2.6 當前項目結(jié)構(gòu) 160
7.2.7 運行效果 160
7.2.8 實例易錯點 160
7.3 @Mapper注解詳解 162
7.3.1 @Mapper和XML形式的對應(yīng)
關(guān)系 162
7.3.2 MyBatis的注解式編程多表
查詢 162
7.3.3 MyBatis的注解式編程分頁
查詢 163
7.3.4 注冊DataSource數(shù)據(jù)源 165
7.4 【實例】Spring Boot整合
spring-data-jpa 166
7.4.1 實例背景 166
7.4.2 添加Pom文件 166
7.4.3 添加資源配置文件中的相關(guān)
信息 166
7.4.4 添加實體類映射 167
7.4.5 添加JPA的dao層 168
7.4.6 添加Controller控制層查詢JPA的
dao層 169
7.4.7 當前項目結(jié)構(gòu) 170
7.4.8 運行結(jié)果 170
7.4.9 實例易錯點 170
7.5 本章小結(jié) 171
7.6 習題 171
第8章 微服務(wù)事務(wù) 172
8.1 @Transactional注解 172
8.1.1 @Transactional聲明式事務(wù)的
傳播行為 173
8.1.2 臟讀、不可重復(fù)讀與幻讀 173
8.1.3 @Transactional聲明式事務(wù)的
隔離級別 174
8.1.4 @Transactional聲明式事務(wù)的
超時時間 175
8.1.5 @Transactional聲明式事務(wù)的
只讀 175
8.1.6 @Transactional聲明式事務(wù)指定
異常 176
8.2 【實例】Spring Boot整合聲明式
事務(wù) 176
8.2.1 實例背景 176
8.2.2 整合@Transactional的Service層
編寫 177
8.2.3 整合@Transactional的Controller層
編寫 178
8.2.4 當前項目結(jié)構(gòu) 179
8.2.5 運行結(jié)果 179
8.2.6 實例易錯點 180
8.3 本章小結(jié) 181
8.4 習題 181
第9章 微服務(wù)的緩存與分布式的消息
通信 182
9.1 Redis 182
9.1.1 BSD協(xié)議 182
9.1.2 Java與Redis的歷史 183
9.1.3 Spring Data Redis 183
9.2 【實例】微服務(wù)整合Spring Data
Redis增刪改查 184
9.2.1 實例背景 184
9.2.2 編寫application.properties資源
配置文件 184
9.2.3 配置RedisTemplate模板 185
9.2.4 編寫操作Redis的工具類 186
9.2.5 編寫實體類及接口調(diào)用 188
9.2.6 當前項目結(jié)構(gòu) 189
9.2.7 運行結(jié)果 189
9.2.8 實例易錯點 190
9.3 【實例】分布式使用Redis實現(xiàn)
消息通信 190
9.3.1 消息通信應(yīng)用場景 190
9.3.2 Redis與MQ一系列消息隊列的
區(qū)別 191
9.3.3 實例背景 191
9.3.4 在send微服務(wù)中配置模板 192
9.3.5 在send微服務(wù)中定時向隊列
發(fā)布數(shù)據(jù) 192
9.3.6 在listener微服務(wù)中編寫訂閱渠道
的配置信息 193
9.3.7 在listener微服務(wù)中編寫監(jiān)聽
實現(xiàn)類 195
9.3.8 當前項目結(jié)構(gòu) 195
9.3.9 send微服務(wù)與listener微服務(wù)運行
結(jié)果 196
9.3.10 實例易錯點 196
9.4 Spring Cache與Spring Data Redis
的區(qū)別 196
9.5 【實例】保持MySQL與Redis
數(shù)據(jù)一致性 197
9.5.1 實例背景 197
9.5.2 編寫資源配置文件 198
9.5.3 編寫實體類Java Bean 198
9.5.4 編寫JPA倉庫 199
9.5.5 編寫Service接口及實現(xiàn)類 199
9.5.6 編寫Controller接口進行測試 202
9.5.7 當前項目結(jié)構(gòu) 202
9.5.8 運行結(jié)果 202
9.5.9 實例易錯點 203
9.6 本章小結(jié) 204
9.7 習題 204
第10章 微服務(wù)的任務(wù)調(diào)度與分布式的
任務(wù)調(diào)度 205
10.1 【實例】微服務(wù)整合任務(wù)調(diào)度 205
10.1.1 實例背景 205
10.1.2 編寫任務(wù)調(diào)度實現(xiàn)類 205
10.1.3 編寫資源配置文件 206
10.1.4 當前項目結(jié)構(gòu) 206
10.1.5 運行效果 206
10.1.6 實例易錯點 206
10.2 @Scheduled注解詳解 207
10.2.1 cron表達式 207
10.2.2 每個字段允許值 207
10.2.3 cron特殊字符意義 208
10.2.4 常用cron表達式 208
10.3 任務(wù)調(diào)度的分布式 209
10.3.1 任務(wù)調(diào)度的分布式解決方案 209
10.3.2 任務(wù)調(diào)度的分布式實現(xiàn)原理 210
10.4 【實例】微服務(wù)整合任務(wù)調(diào)度
分布式 210
10.4.1 實例背景 210
10.4.2 增加Quartz依賴 210
10.4.3 在數(shù)據(jù)庫中增加Quartz分布式
的管理表 210
10.4.4 編寫資源配置文件 211
10.4.5 創(chuàng)建任務(wù)調(diào)度管理Java Bean 212
10.4.6 創(chuàng)建所需執(zhí)行的任務(wù) 213
10.4.7 創(chuàng)建執(zhí)行任務(wù)的操作類 213
10.4.8 增加控制層 216
10.4.9 當前項目結(jié)構(gòu) 218
10.4.10 運行效果 218
10.4.11 實例易錯點 219
10.5 本章小結(jié) 220
10.6 習題 220
第11章 微服務(wù)的文件上傳與分布式
文件管理 221
11.1 文件上傳/下載原理 221
11.1.1 SpringMVC文件上傳原理 223
11.1.2 文件下載原理 225
11.2 【實例】微服務(wù)的單文件和
多文件上傳 226
11.2.1 實例背景 226
11.2.2 編寫application.properties資
源配置文件 227
11.2.3 編寫相關(guān)接口 228
11.2.4 編寫前臺頁面 230
11.2.5 當前項目結(jié)構(gòu) 231
11.2.6 運行結(jié)果 232
11.2.7 實例易錯點 233
11.3 分布式文件管理 235
11.3.1 分布式文件管理特性 235
11.3.2 分布式文件管理解決的問題 235
11.3.3 分布式文件管理解決方案 235
11.4 FastDFS解決方案 235
11.4.1 FastDFS的存儲策略 236
11.4.2 FastDFS的文件上傳過程 236
11.4.3 FastDFS的文件同步過程 236
11.4.4 FastDFS的文件下載過程 237
11.5 FastDFS的安裝部署 237
11.5.1 安裝LibFastCommon 237
11.5.2 安裝FastDFS 237
11.5.3 配置FastDFS的跟蹤服務(wù)器 238
11.5.4 配置FastDFS的數(shù)據(jù)存儲
服務(wù)器 239
11.5.5 配置FastDFS的客戶端
并測試 240
11.5.6 安裝Nginx部署FastDFS 240
11.6 【實例】分布式微服務(wù)整合
FastDFS 243
11.6.1 實例背景 243
11.6.2 編寫FastDFS核心配置類 244
11.6.3 編寫FastDFS工具類 244
11.6.4 編寫測試接口 245
11.6.5 當前項目結(jié)構(gòu) 246
11.6.6 運行結(jié)果 246
11.6.7 實例易錯點 247
11.7 本章小結(jié) 248
11.8 習題 248
第12章 擴展與部署 249
12.1 微服務(wù)分布式架構(gòu)相關(guān)方案
總結(jié) 249
12.1.1 解決方案與目標 249
12.1.2 分布式部分技術(shù)細節(jié)擴展 250
12.1.3 動靜分離 250
12.1.4 前后端分離 250
12.1.5 數(shù)據(jù)庫讀寫分離與主從分離 251
12.1.6 應(yīng)用層與數(shù)據(jù)層分離 251
12.1.7 CDN加速 251
12.1.8 異步架構(gòu) 251
12.1.9 響應(yīng)式編程 251
12.1.10 冗余化管理 252
12.1.11 灰度發(fā)布 252
12.1.12 頁面靜態(tài)化 252
12.1.13 服務(wù)端主動推送 253
12.2 微服務(wù)擴展 253
12.2.1 微服務(wù)整合日志 253
12.2.2 微服務(wù)整合單元測試 253
12.2.3 微服務(wù)整合全局異常 253
12.2.4 微服務(wù)整合JSR-303驗證機制 254
12.2.5 微服務(wù)整合國際化 254
12.2.6 微服務(wù)整合安全與認證 254
12.2.7 微服務(wù)整合WebSocket協(xié)議 254
12.2.8 微服務(wù)整合HTTPS 255
12.2.9 微服務(wù)整合批處理 255
12.2.10 微服務(wù)整合lombok 255
12.2.11 微服務(wù)整合異步消息驅(qū)動 255
12.2.12 分布式鏈路監(jiān)控 255
12.2.13 分布式單點登錄 256
12.3 【實例】分布式網(wǎng)關(guān)的初步
測試 256
12.3.1 實例背景 256
12.3.2 使用資源配置文件的方式配置
分布式網(wǎng)關(guān) 256
12.3.3 使用注冊Bean的方式配置
分布式網(wǎng)關(guān) 257
12.3.4 運行結(jié)果 258
12.4 微服務(wù)打包 258
12.4.1 Jar包 258
12.4.2 War包 259
12.5 本章小結(jié) 259
12.6 習題 259
參考文獻 260