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

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

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

定 價(jià):¥98.00

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

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

內(nèi)容簡介

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

作者簡介

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

圖書目錄

第Ⅰ部分 基礎(chǔ)知識
第1 章 Quarkus、MicroProfile 和
Kubernetes 簡介. 3
1.1 什么是微服務(wù)3
1.1.1 微服務(wù)的興起.6
1.1.2 微服務(wù)架構(gòu)6
1.1.3 微服務(wù)規(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 運(yùn)行時(shí)效率 11
1.4 Kubernetes 12
1.5 Kubernetes 原生微服務(wù) 15
1.6 本章小結(jié) 16
第2 章 初次開發(fā)Quarkus 應(yīng)用19
2.1 創(chuàng)建項(xiàng)目 19
2.2 使用實(shí)時(shí)編碼進(jìn)行開發(fā) 24
2.3 編寫測試 32
2.4 生成原生可執(zhí)行程序 37
2.5 在Kubernetes 上運(yùn)行應(yīng)用. 40
2.5.1 生成 Kubernetes YAML . 40
2.5.2 應(yīng)用打包 43
2.5.3 應(yīng)用部署與運(yùn)行. 43
2.6 本章小結(jié) 45
第Ⅱ部分 微服務(wù)開發(fā)
第3 章 微服務(wù)配置.49
3.1 MicroProfile Config架構(gòu)概述 50
3.2 訪問配置 50
3.3 銀行服務(wù) 51
3.3.1 創(chuàng)建銀行服務(wù). 51
3.3.2 配置銀行服務(wù)的名稱字段. 53
3.4 配置源. 54
3.5 配置mobileBanking 字段 57
3.6 使用@ConfigProperties 對配置屬性分組. 57
3.7 Quarkus 特有的配置功能 59
3.7.1 Quarkus 配置編組. 59
3.7.2 配置屬性表達(dá)式 60
3.7.3 Quarkus ConfigMapping 功能 61
3.7.4 運(yùn)行期和構(gòu)建期配置屬性. 62
3.8 Kubernetes 上的配置 63
3.8.1 Kubernetes 上的常見配置源. 63
3.8.2 在Quarkus 應(yīng)用中使用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 原生微服務(wù)開發(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 章 微服務(wù)客戶端87
5.1 MicroProfile REST Client規(guī)范 88
5.2 定義服務(wù)接口 89
5.2.1 CDI REST 客戶端 90
5.2.2 以編程方式使用REST客戶端 95
5.2.3 選用CDI 還是編程式API. 96
5.2.4 異步響應(yīng)類型. 96
5.3 定制REST 客戶端. 98
5.3.1 客戶端請求頭. 98
5.3.2 聲明提供程序101
5.4 本章小結(jié).106
第6 章 應(yīng)用的健康管理.107
6.1 開發(fā)者在應(yīng)用健康管理領(lǐng)域日益重要的地位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 開始學(xué)習(xí)MicroProfile Health.110
6.3.1 賬戶服務(wù)中的MicroProfile
Health 存活狀態(tài).112
6.3.2 為賬戶服務(wù)創(chuàng)建存活健康檢查113
6.3.3 賬戶服務(wù)的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 章 應(yīng)用韌性策略 127
7.1 韌性策略簡介127
7.2 用@Asynchronous 啟用單獨(dú)的線程執(zhí)行方法128
7.3 用艙壁模式限制并發(fā)128
7.4 在交易服務(wù)中使用艙壁.130
7.5 以降級處理的方式處理異常.131
7.6 為調(diào)用指定超時(shí).132
7.7 用@Retry 從臨時(shí)故障中恢復(fù).135
7.8 用熔斷器避免持續(xù)故障.136
7.8.1 MicroProfile Fault Tolerance規(guī)范中的@CircuitBreaker 136
7.8.2 熔斷器的工作原理.137
7.8.3 更新交易服務(wù),運(yùn)用@CircuitBreaker138
7.8.4 測試熔斷器140
7.9 用配置屬性覆蓋注解參數(shù)142
7.10 部署到Kubernetes.144
7.11 本章小結(jié).145
第8 章 命令式世界的反應(yīng)式編程 147
8.1 反應(yīng)式編程的示例147
8.2 反應(yīng)式流149
8.2.1 發(fā)布者、訂閱者和處理者149
8.2.2 回壓的重要性150
8.3 Quarkus 中的反應(yīng)式消息.152
8.3.1 借用生成器結(jié)合使用命令式與反應(yīng)式編程152
8.3.2 關(guān)于阻塞.155
8.3.3 以內(nèi)存模式測試157
8.4 原理分析.160
8.4.1 MicroProfile 反應(yīng)式消息規(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微服務(wù)171
9.1 Quarkus 與Spring API兼容性簡介171
9.2 Spring 依賴注入和配置的兼容性172
9.2.1 搭建Spring Cloud 配置服務(wù)器.173
9.2.2 將Spring 配置服務(wù)器用作配置源.174
9.2.3 將銀行服務(wù)轉(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中的實(shí)現(xiàn)原理184
9.7 常見的Quarkus/Spring 兼容性相關(guān)的問題184
9.8 對比Spring Boot 與Quarkus的啟動過程185
9.9 本章小結(jié).186
第Ⅲ部分 可觀測性、API 定義和微服務(wù)安全
第10 章 記錄指標(biāo) 189
10.1 指標(biāo)在微服務(wù)架構(gòu)中的角色189
10.2 了解MicroProfile Metrics規(guī)范.190
10.2.1 利用Prometheus 和Grafana繪制指標(biāo)圖線.191
10.2.2 MicroProfile Metrics 規(guī)范197
10.2.3 為賬戶服務(wù)添加埋點(diǎn)201
10.2.4 為交易服務(wù)添加埋點(diǎn)202
10.2.5 創(chuàng)建業(yè)務(wù)指標(biāo).209
10.2.6 MicroProfile Metrics 與MicroProfile Fault Tolerance、JAX-RS 的集成. 211
10.2.7 Micrometer 指標(biāo)213
10.2.8 模擬繁忙的生產(chǎn)系統(tǒng)215
10.3 本章小結(jié).216
第11 章 微服務(wù)跟蹤 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 跟蹤微服務(wù).222
11.3 跟蹤的規(guī)范226
11.3.1 OpenTracing.226
11.3.2 MicroProfile OpenTracing 227
11.3.3 OpenTelemetry227
11.4 在應(yīng)用中定制跟蹤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 原生微服務(wù)開發(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 應(yīng)用信息244
12.2.2 定制輸出內(nèi)容的結(jié)構(gòu)246
12.2.3 定義操作247
12.2.4 操作的響應(yīng)248
12.2.5 為操作添加標(biāo)簽251
12.2.6 過濾 OpenAPI 的內(nèi)容252
12.3 設(shè)計(jì)先行開發(fā)253
12.3.1 從文件加載OpenAPI253
12.3.2 混用文件與注解254
12.4 代碼先行還是OpenAPI先行255
12.5 本章小結(jié).255
第13 章 微服務(wù)安全257
13.1 認(rèn)證和授權(quán)簡介257
13.2 使用基于文件的認(rèn)證與授權(quán)259
13.3 基于OpenID Connect 的認(rèn)證與授權(quán)263
13.3.1 OpenID Connect(OIDC)
簡介264
13.3.2 OIDC 與Keycloak264
13.3.3 使用OpenID Connect 訪問受保護(hù)的資源.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 為交易服務(wù)添加安全保護(hù)276
13.6 傳遞JWT278
13.6.1 為賬戶服務(wù)API 端點(diǎn)添加安全保護(hù)278
13.6.2 由交易服務(wù)向賬戶服務(wù)傳遞JWT 令牌.279
13.7 在Kubernetes 上運(yùn)行服務(wù).280
13.8 本章小結(jié).281

本目錄推薦

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