注冊 | 登錄讀書好,好讀書,讀好書!
讀書網(wǎng)-DuShu.com
當前位置: 首頁出版圖書科學技術(shù)計算機/網(wǎng)絡軟件與程序設計Kubernetes原生微服務開發(fā)

Kubernetes原生微服務開發(fā)

Kubernetes原生微服務開發(fā)

定 價:¥98.00

作 者: [美] 約翰·克林甘(John Clingan)、肯·芬尼根(Ken Finnigan)著,陳計節(jié) 張圣奇 譯
出版社: 清華大學出版社
叢編項:
標 簽: 暫缺

購買這本書可以去


ISBN: 9787302630623 出版時間: 2023-06-01 包裝: 平裝-膠訂
開本: 16開 頁數(shù): 字數(shù):  

內(nèi)容簡介

  運用新的“Kubernetes優(yōu)先”工具高效地開發(fā)微服務!Quarkus與容器和Kubernetes的結(jié)合渾然天成,從根本上簡化了微服務的開發(fā)與部署。Quarkus這個功能強大的框架從一開始就是基于Java構(gòu)建的,因而能與現(xiàn)有的JVM代碼庫無縫集成,極大地縮短了啟動時間,減少了內(nèi)存消耗量。 在《Kubernetes原生微服務開發(fā)》的指導下,你將使用容器、Kubernetes和Quarkus框架開發(fā)微服務。將首先開發(fā)基于Quarkus和MicroProfile API的可部署應用;此后,將了解如何借助Quarkus天然的啟動速度和運行速度優(yōu)勢,通過運用GraalVM原生編譯,來獲得性能躍升。在學習過程中,你將體驗到如何在Quarkus應用中集成Spring開發(fā),并吸收作者關于微服務監(jiān)控和管理的真知灼見。 主要內(nèi)容 ? 在Kubernetes上部署企業(yè)級Java應用 ? 運用Quarkus運行時框架開發(fā)應用 ? 運用GraalVM原生編譯獲得**性能 ? 充分運用MicroProfile規(guī)范

作者簡介

  John Clingan 是紅帽高級產(chǎn)品主管,研究方向是企業(yè)級Java標準和Quarkus。Ken Finnigan 是Workday高級軟件工程師主管,此前在紅帽的Quarkus團隊工作。

圖書目錄

第Ⅰ部分 基礎知識
第1 章 Quarkus、MicroProfile 和
Kubernetes 簡介. 3
1.1 什么是微服務3
1.1.1 微服務的興起.6
1.1.2 微服務架構(gòu)6
1.1.3 微服務規(guī)范的需求7
1.2 MicroProfile 規(guī)范.7
1.2.1 MicroProfile 的發(fā)展歷程.8
1.2.2 MicroProfile 社區(qū)核心原則9
1.3 Quarkus 10
1.3.1 快樂開發(fā) 10
1.3.2 對MicroProfile 的支持 11
1.3.3 運行時效率 11
1.4 Kubernetes 12
1.5 Kubernetes 原生微服務 15
1.6 本章小結(jié) 16
第2 章 初次開發(fā)Quarkus 應用19
2.1 創(chuàng)建項目 19
2.2 使用實時編碼進行開發(fā) 24
2.3 編寫測試 32
2.4 生成原生可執(zhí)行程序 37
2.5 在Kubernetes 上運行應用. 40
2.5.1 生成 Kubernetes YAML . 40
2.5.2 應用打包 43
2.5.3 應用部署與運行. 43
2.6 本章小結(jié) 45
第Ⅱ部分 微服務開發(fā)
第3 章 微服務配置.49
3.1 MicroProfile Config架構(gòu)概述 50
3.2 訪問配置 50
3.3 銀行服務 51
3.3.1 創(chuàng)建銀行服務. 51
3.3.2 配置銀行服務的名稱字段. 53
3.4 配置源. 54
3.5 配置mobileBanking 字段 57
3.6 使用@ConfigProperties 對配置屬性分組. 57
3.7 Quarkus 特有的配置功能 59
3.7.1 Quarkus 配置編組. 59
3.7.2 配置屬性表達式 60
3.7.3 Quarkus ConfigMapping 功能 61
3.7.4 運行期和構(gòu)建期配置屬性. 62
3.8 Kubernetes 上的配置 63
3.8.1 Kubernetes 上的常見配置源. 63
3.8.2 在Quarkus 應用中使用ConfigMap 65
3.8.3 編輯ConfigMap. 66
3.8.4 Kubernetes Secret 67
3.9 本章小結(jié) 69
第4 章 使用Panache 訪問數(shù)據(jù)71
4.1 數(shù)據(jù)源. 71
4.2 JPA 73
4.3 簡化數(shù)據(jù)庫開發(fā) 78
X Kubernetes 原生微服務開發(fā)
4.3.1 活動記錄 78
4.3.2 數(shù)據(jù)倉儲 81
4.3.3 數(shù)據(jù)訪問模式選型 83
4.4 部署到Kubernetes 84
4.4.1 部署PostgreSQL 數(shù)據(jù)庫 84
4.4.2 打包與部署 85
4.5 本章小結(jié) 86
第5 章 微服務客戶端87
5.1 MicroProfile REST Client規(guī)范 88
5.2 定義服務接口 89
5.2.1 CDI REST 客戶端 90
5.2.2 以編程方式使用REST客戶端 95
5.2.3 選用CDI 還是編程式API. 96
5.2.4 異步響應類型. 96
5.3 定制REST 客戶端. 98
5.3.1 客戶端請求頭. 98
5.3.2 聲明提供程序101
5.4 本章小結(jié).106
第6 章 應用的健康管理.107
6.1 開發(fā)者在應用健康管理領域日益重要的地位107
6.2 MicroProfile Health 規(guī)范108
6.2.1 存活狀態(tài)與就緒狀態(tài).109
6.2.2 確定存活狀態(tài)與就緒狀態(tài)109
6.3 開始學習MicroProfile Health.110
6.3.1 賬戶服務中的MicroProfile
Health 存活狀態(tài).112
6.3.2 為賬戶服務創(chuàng)建存活健康檢查113
6.3.3 賬戶服務的MicroProfile Health
就緒狀態(tài).114
6.3.4 禁用第三方就緒健康檢查115
6.3.5 創(chuàng)建新的就緒健康檢查115
6.3.6 Quarkus 健康分組118
6.3.7 使用Quarkus 健康狀態(tài)界面 119
6.4 Kubernetes 存活和就緒探針.120
6.4.1 定制健康檢查屬性.121
6.4.2 部署到Kubernetes122
6.4.3 測試Kubernetes 中的就緒健康檢查124
6.5 本章小結(jié)126
第7 章 應用韌性策略 127
7.1 韌性策略簡介127
7.2 用@Asynchronous 啟用單獨的線程執(zhí)行方法128
7.3 用艙壁模式限制并發(fā)128
7.4 在交易服務中使用艙壁.130
7.5 以降級處理的方式處理異常.131
7.6 為調(diào)用指定超時.132
7.7 用@Retry 從臨時故障中恢復.135
7.8 用熔斷器避免持續(xù)故障.136
7.8.1 MicroProfile Fault Tolerance規(guī)范中的@CircuitBreaker 136
7.8.2 熔斷器的工作原理.137
7.8.3 更新交易服務,運用@CircuitBreaker138
7.8.4 測試熔斷器140
7.9 用配置屬性覆蓋注解參數(shù)142
7.10 部署到Kubernetes.144
7.11 本章小結(jié).145
第8 章 命令式世界的反應式編程 147
8.1 反應式編程的示例147
8.2 反應式流149
8.2.1 發(fā)布者、訂閱者和處理者149
8.2.2 回壓的重要性150
8.3 Quarkus 中的反應式消息.152
8.3.1 借用生成器結(jié)合使用命令式與反應式編程152
8.3.2 關于阻塞.155
8.3.3 以內(nèi)存模式測試157
8.4 原理分析.160
8.4.1 MicroProfile 反應式消息規(guī)范160
8.4.2 消息內(nèi)容和元數(shù)據(jù).161
8.4.3 消息流中的消息164
8.5 部署到Kubernetes164
8.5.1 Minikube 中的Apache Kafka 165
8.5.2 匯總所有步驟167
8.6 本章小結(jié).169
第9 章 在Quarkus 中開發(fā)Spring微服務171
9.1 Quarkus 與Spring API兼容性簡介171
9.2 Spring 依賴注入和配置的兼容性172
9.2.1 搭建Spring Cloud 配置服務器.173
9.2.2 將Spring 配置服務器用作配置源.174
9.2.3 將銀行服務轉(zhuǎn)換為使用Spring Configuration API175
9.3 Quarkus 與Spring Web API的兼容性176
9.4 Quarkus 與Spring Data JPA的兼容性179
9.5 部署到Kubernetes183
9.6 Spring API 兼容性在Quarkus中的實現(xiàn)原理184
9.7 常見的Quarkus/Spring 兼容性相關的問題184
9.8 對比Spring Boot 與Quarkus的啟動過程185
9.9 本章小結(jié).186
第Ⅲ部分 可觀測性、API 定義和微服務安全
第10 章 記錄指標 189
10.1 指標在微服務架構(gòu)中的角色189
10.2 了解MicroProfile Metrics規(guī)范.190
10.2.1 利用Prometheus 和Grafana繪制指標圖線.191
10.2.2 MicroProfile Metrics 規(guī)范197
10.2.3 為賬戶服務添加埋點201
10.2.4 為交易服務添加埋點202
10.2.5 創(chuàng)建業(yè)務指標.209
10.2.6 MicroProfile Metrics 與MicroProfile Fault Tolerance、JAX-RS 的集成. 211
10.2.7 Micrometer 指標213
10.2.8 模擬繁忙的生產(chǎn)系統(tǒng)215
10.3 本章小結(jié).216
第11 章 微服務跟蹤 217
11.1 跟蹤的工作原理.218
11.2 Jaeger219
11.2.1 跟蹤采樣219
11.2.2 配置 Minikube 環(huán)境220
11.2.3 安裝Jaeger 220
11.2.4 使用Jaeger 跟蹤微服務.222
11.3 跟蹤的規(guī)范226
11.3.1 OpenTracing.226
11.3.2 MicroProfile OpenTracing 227
11.3.3 OpenTelemetry227
11.4 在應用中定制跟蹤228
11.4.1 使用@Traced228
11.4.2 注入跟蹤器.228
11.4.3 跟蹤數(shù)據(jù)庫調(diào)用230
11.4.4 跟蹤Kafka 消息232
11.5 本章小結(jié).238
XII Kubernetes 原生微服務開發(fā)
第12 章 API 可視化239
12.1 在Swagger UI 中查看OpenAPI 文檔240
12.1.1 啟用OpenAPI.240
12.1.2 Swagger UI 242
12.2 MicroProfile OpenAPI244
12.2.1 應用信息244
12.2.2 定制輸出內(nèi)容的結(jié)構(gòu)246
12.2.3 定義操作247
12.2.4 操作的響應248
12.2.5 為操作添加標簽251
12.2.6 過濾 OpenAPI 的內(nèi)容252
12.3 設計先行開發(fā)253
12.3.1 從文件加載OpenAPI253
12.3.2 混用文件與注解254
12.4 代碼先行還是OpenAPI先行255
12.5 本章小結(jié).255
第13 章 微服務安全257
13.1 認證和授權(quán)簡介257
13.2 使用基于文件的認證與授權(quán)259
13.3 基于OpenID Connect 的認證與授權(quán)263
13.3.1 OpenID Connect(OIDC)
簡介264
13.3.2 OIDC 與Keycloak264
13.3.3 使用OpenID Connect 訪問受保護的資源.266
13.3.4 測試授權(quán)碼流程268
13.4 JSON Web 令牌和
MicroProfile JWT271
13.4.1 JWT 令牌的頭部272
13.4.2 JWT 令牌的正文272
13.4.3 JWT 簽名.274
13.5 使用MicroProfile JWT 為交易服務添加安全保護276
13.6 傳遞JWT278
13.6.1 為賬戶服務API 端點添加安全保護278
13.6.2 由交易服務向賬戶服務傳遞JWT 令牌.279
13.7 在Kubernetes 上運行服務.280
13.8 本章小結(jié).281

本目錄推薦

掃描二維碼
Copyright ? 讀書網(wǎng) m.ranfinancial.com 2005-2020, All Rights Reserved.
鄂ICP備15019699號 鄂公網(wǎng)安備 42010302001612號