精通Spring Cloud微服务架构作者: [美]闵可夫斯基出版时间: 2019年版内容简介 本书详细阐述了与Spring Cloud微服务框架相关的基本解决方案,主要包括微服务简介、使用微服务的Spring、Spring Cloud概述、服务发现、使用Spring Cloud Config进行分布式配置、微服务之间的通信、高级负载均衡和断路器、使用API网关进行路由和过滤、分布式日志记录和跟踪、其他配置和发现功能、消息驱动的微服务、保护API的安全、测试Java微服务、Docker支持、云平台上的Spring微服务等内容。此外,本书还提供了相应的示例、代码,以帮助读者进一步理解相关方案的实现过程。 本书适合作为高等院校计算机及相关专业的教材和教学参考书,也可作为相关开发人员的自学教材和参考手册。目录第一部分 微服务架构和Spring Cloud项目基础知识第1章 微服务简介 31.1 微服务的优点 31.2 使用Spring Framework构建微服务 41.3 云原生应用程序开发方法 41.4 了解微服务架构 51.4.1 理解服务发现的必要性 71.4.2 服务之间的通信 91.4.3 故障和断路器 111.5 小结 11第2章 使用微服务的Spring 132.1 关于Spring Boot 132.2 使用Spring Boot开发应用程序 152.2.1 自定义配置文件 172.2.2 创建RESTful Web服务 202.3 API文档 232.3.1 联合使用Swagger 2和Spring Boot 232.3.2 使用Swagger UI测试API 242.4 Spring Boot执行器功能 272.4.1 应用信息 272.4.2 健康信息 292.4.3 指标信息 302.5 开发者工具 322.6 将应用程序与数据库集成 332.7 运行应用程序 362.8 小结 40第3章 Spring Cloud概述 413.1 从基础开始 413.1.1 Netflix OSS 423.1.2 使用Eureka进行服务发现 433.1.3 使用Zuul路由 433.1.4 使用Ribbon实现负载均衡 443.1.5 编写Java HTTP客户端 443.1.6 Hystrix的延迟和容错能力 443.1.7 使用Archaius进行配置管理 453.2 发现和分布式配置 453.2.1 可选替代方案—Consul 463.2.2 Apache Zookeeper 463.2.3 其他项目 473.3 使用Sleuth进行分布式跟踪 473.4 消息传递和集成 483.5 云平台支持 493.6 其他有用的库 503.6.1 安全性 513.6.2 自动化测试 513.6.3 集群功能 513.7 项目概述 513.8 版本列车 523.9 小结 54第二部分 微服务架构常见元素和Spring Cloud实现第4章 服务发现 574.1 在服务器端运行Eureka 574.2 在客户端启用Eureka 594.2.1 关机时取消注册 604.2.2 以编程方式使用发现客户端 624.3 高级配置设置 634.3.1 刷新注册表 634.3.2 更改实例标识符 654.3.3 选择使用IP地址 664.3.4 响应缓存 664.4 启用客户端和服务器之间的安全通信 674.5 Eureka API 694.6 副本和高可用性 704.6.1 样本解决方案的架构 704.6.2 构建示例应用程序 714.6.3 故障转移 754.7 区域 764.7.1 具有独立服务器的区域 774.7.2 构建示例应用程序 784.8 小结 80第5章 使用Spring Cloud Config 进行分布式配置 835.1 HTTP API资源简介 845.2 构建服务器端应用程序 865.3 构建客户端应用程序 875.4 客户端引导方法 885.5 存储库后端类型 915.5.1 文件系统后端 915.5.2 Git后端 925.5.3 Vault后端 965.6 其他功能 985.6.1 启动失败和重试 985.6.2 保护客户端的安全 995.7 自动重新加载配置 995.7.1 解决方案架构 995.7.2 [email protected] 1005.7.3 使用来自消息代理的事件 1035.7.4 监视Config Server上的存储库更改 1045.8 小结 108第6章 微服务之间的通信 1096.1 不同类型的通信 1096.2 使用Spring Cloud进行同步通信 1096.3 使用Ribbon执行负载均衡 1106.3.1 使用Ribbon客户端启用微服务之间的通信 1106.3.2 静态负载均衡配置 1116.3.3 调用其他服务 1126.4 将RestTemplate与服务发现结合使用 1156.5 使用Feign客户端 1186.5.1 对不同区域的支持 1186.5.2 为应用程序启用Feign 1196.5.3 继承支持 1236.5.4 手动创建客户端 1246.5.5 客户端的自定义 1246.6 小结 126第7章 高级负载均衡和断路器 1277.1 负载均衡规则 1277.1.1 WeightedResponseTime规则 1287.1.2 引入Hoverfly进行测试 1287.1.3 测试规则 1297.2 自定义Ribbon客户端 1317.3 带Hystrix的断路器模式 1337.3.1 使用Hystrix构建应用程序 1337.3.2 跳闸断路器 1377.4 监控延迟和容错 1407.4.1 公开Hystrix的指标流 1417.4.2 Hystrix仪表板 1427.5 故障和带有Feign的断路器模式 1497.5.1 重试与Ribbon的连接 1497.5.2 Hystrix对Feign的支持 1507.6 小结 153第8章 使用API网关进行路由和过滤 1558.1 使用Spring Cloud Netflix Zuul 1558.1.1 构建网关应用程序 1568.1.2 与服务发现集成 1578.1.3 自定义路由配置 1588.1.4 管理端点 1618.1.5 提供Hystrix回退bean 1628.1.6 Zuul过滤器 1648.2 使用Spring Cloud Gateway 1668.2.1 为项目启用Spring Cloud Gateway 1678.2.2 内置谓词和过滤器 1688.2.3 微服务的网关 1708.2.4 与服务发现集成 1728.3 小结 173第9章 分布式日志记录和跟踪 1759.1 微服务的最佳日志记录实践 1759.2 使用Spring Boot记录日志 1779.3 使用ELK Stack集中日志 1799.3.1 在机器上设置ELK堆栈 1809.3.2 将应用程序与ELK Stack集成 1819.4 Spring Cloud Sleuth 1889.4.1 将Sleuth与应用程序集成 1899.4.2 使用Kibana搜索事件 1909.4.3 集成Sleuth和Zipkin 1929.5 小结 198第10章 其他配置和发现功能 19910.1 使用Spring Cloud Consul 19910.1.1 运行Consul代理 20010.1.2 在客户端集成 20110.1.3 服务发现 20110.1.4 分布式配置 20810.2 使用Spring Cloud Zookeeper 21210.2.1 运行Zookeeper 21310.2.2 服务发现 21410.2.3 分布式配置 21610.3 小结 217第11章 消息驱动的微服务 21911.1 了解Spring Cloud Stream 21911.2 构建消息传递系统 22011.2.1 启用Spring Cloud Stream 22011.2.2 声明和绑定频道 22211.2.3 自定义与RabbitMQ代理的连接 22411.2.4 与其他Spring Cloud项目集成 22811.3 发布/订阅模型 23111.3.1 运行示例系统 23211.3.2 扩展和分组 23311.4 配置选项 23811.4.1 Spring Cloud Stream属性 23811.4.2 绑定属性 23911.5 高级编程模型 24011.5.1 制作消息 24011.5.2 转换 24011.5.3 有条件地使用消息 24111.6 使用Apache Kafka 24211.6.1 运行Kafka 24211.6.2 自定义应用程序设置 24311.6.3 Kafka Streams API支持 24411.6.4 配置属性 24511.7 多个绑定器 24511.8 小结 247第12章 保护API的安全 24912.1 为Spring Boot启用HTTPS 24912.2 保证发现服务器的安全 25112.2.1 注册安全的应用程序 25112.2.2 通过HTTPS服务Eureka 25112.3 保证配置服务器的安全 25512.3.1 加密和解密 25512.3.2 配置客户端和服务器的身份验证 25712.4 使用OAuth2进行授权 25912.4.1 OAuth2简介 25912.4.2 构建授权服务器 26012.4.3 客户端配置 26412.4.4 使用JDBC后端存储 26612.4.5 服务间授权 26912.4.6 在API网关上启用SSO 27312.5 小结 274第13章 测试Java微服务 27513.1 测试策略 27513.2 测试Spring Boot应用程序 27713.2.1 构建示例应用程序 27813.2.2 与数据库集成 27913.3 单元测试 28013.4 组件测试 28213.4.1 使用内存数据库运行测试 28213.4.2 处理HTTP客户端和服务发现 28313.4.3 实现示例测试 28513.5 集成测试 28613.5.1 对测试进行分类 28613.5.2 捕获HTTP流量 28713.6 契约测试 28913.6.1 使用Pact 28913.6.2 使用Spring Cloud Contract 29413.7 性能测试 30113.8 小结 305第三部分 Docker支持和Spring Cloud平台第14章 Docker支持 30914.1 关于Docker 30914.2 安装Docker 31114.3 常用的Docker命令 31214.3.1 运行和停止容器 31214.3.2 列出并删除容器 31314.3.3 提取和推送镜像 31414.3.4 构建镜像 31514.3.5 创建网络 31614.4 创建具有微服务的Docker镜像 31614.4.1 Dockerfile 31714.4.2 运行容器化微服务 31914.4.3 使用Maven插件构建镜像 32114.4.4 高级Docker镜像 32314.5 持续交付 32514.5.1 将Jenkins与Docker集成 32514.5.2 构建管道 32714.6 使用Kubernetes 33014.6.1 概念和组件 33114.6.2 通过Minikube以本地方式运行Kubernetes 33214.6.3 部署应用程序 33314.6.4 维护集群 33614.7 小结 338第15章 云平台上的Spring微服务 33915.1 Pivotal Cloud Foundry 33915.1.1 使用模式 34015.1.2 准备应用程序 34115.1.3 部署应用程序 34315.1.4 维护 34715.2 Heroku平台 35215.2.1 部署方法 35215.2.2 准备应用程序 35515.2.3 测试部署 35615.3 小结 358 上一篇: 算法零基础一本通 Python版 洪锦魁 2020年版 下一篇: 网络空间安全技术丛书 Web安全防护指南 基础篇 蔡晶晶 2018年版