spring cloud 微服务与实战 网络技术 谭锋 正版pdf下载

spring cloud 微服务与实战 网络技术 谭锋 正版百度网盘pdf下载

作者:
简介:spring cloud 微服务与实战 网络技术 谭锋 正版
出版社:
出版时间:2020-04
pdf下载价格:0.00¥

免费下载


书籍下载


内容介绍

基本信息
书名: spring cloud 微服务与实战 ISBN号: 9787121388248
作者: 谭锋 页数: 389
定价: 106.00元 出版时间: 2020-04-01
装帧: 平装 印刷时间:
出版社: 电子工业出版社 版次: 1
开本: 16开 字数: 588000

主编推荐

"★ 先发售对spring cloud 行系统性介绍的书籍★ 结合作者多年对互联网技术及微服务架构的理解和实践★ 从入门示例、剖析和源码分析等方面讲解每个模块★ 对“实⽤主义者”,直接“show you the code”★ 对“底层探究者”,会补充⼀些性内容,加深理解★ 展示了微服务架构中涉及的核心技术和实现★ 是学微服务架构与分布式系统技术的书籍spring cloud 是一套完整的微服务架构解决方案,它为开发人员提供了一些工具来快速构建分布式系统,这对于中互联网公司来说是一种“福音”,它能帮助企业在应对业务发展的同时,大大减少开发的成本。"

目录

章 微服务的发展史 1
1.1 从单体架构到分布式架构的演 2
1.1.1 单体架构 2
1.1.2 集群及垂直化 3
1.1.3 soa 4
1.1.4 微服务架构 5
1.2 微服务架构带来的挑战 7
1.2.1 微服务架构的优点 7
1.2.2 微服务架构面临的挑战 7
1.3 如何实现微服务架构 8
1.3.1 微服务架构图 8
1.3.2 微服务架构下的技术挑战 9
第2章 微服务解决方案之spring cloud 10
2.1 什么是spring cloud 11
2.2 spring cloud版本简介 12
2.3 spring cloud规范下的实现 13
2.4 spring cloud flix 14
2.5 spring cloud 15
2.5.1 spring cloud 的优势 15
2.5.2 spring cloud 的版本 16
第3章 spring cloud的核心之spring boot 18
3.1 重新认识spring boot 18
3.1.1 spring ioc/di 19
3.1.2 bean装配方式的升级 21
3.1.3 spring boot的价值 23
3.2 快速构建spring boot应用 25
3.3 spring boot自动装配的 26
3.3.1 自动装配的实现 27
3.3.2 enableautoconfiguration 28
3.3.3 autoconfigurationimportselector 29
3.3.4 自动装配分析 31
3.3.5 @conditional条件装配 34
3.3.6 spring-autoconfigure-metadata 37
3.4 手写实现一个starter 38
3.4.1 starter的命名规范 38
3.4.2 实现基于redis的starter 38
3.5 本章小结 41
第4章 微服务架构下的服务治理 42
4.1 如何理解apache dubbo 43
4.2 apache dubbo实现远程通信 44
4.3 spring boot集成apache dubbo 48
4.4 快速上手zookeeper 52
4.4.1 zookeeper的安装 52
4.4.2 zookeeper的数据结构 52
4.4.3 zookeeper的特性 53
4.4.4 watcher机制 54
4.4.5 常见应用场景分析 54
4.5 apache dubbo集成zookeeper实现服务注册 56
4.5.1 apache dubbo集成zookeeper实现服务注册的步骤 57
4.5.2 zookeeper注册中心的实现 59
4.6 实战dubbo spring cloud 60
4.6.1 实现dubbo服务提供方 60
4.6.2 实现dubbo服务调用方 63
4.7 apache dubbo的不错应用 65
4.7.1 集群容错 66
4.7.2 负载均衡 67
4.7.3 服务降级 68
4.7.4 主机绑定规则 69
4.8 apache dubbo核心源码分析 70
4.8.1 源码构建 71
4.8.2 dubbo的核心之spi 71
4.8.3 无处不在的自适应扩展点 81
4.8.4 dubbo中的ioc和aop 85
4.8.5 dubbo和spring集成的 89
4.9 本章小结 95
第5章 服务注册与发现 97
5.1 什么是 nacos 98
5.2 nacos的基本使用 99
5.2.1 nacos的安装 99
5.2.2 nacos服务注册发现相关api说明 100
5.2.3 nacos集成spring boot实现服务注册与发现 101
5.3 nacos的高可用部署 103
5.3.1 安装环境要求 104
5.3.2 安装包及环境准备 104
5.3.3 集群配置 104
5.3.4 配置mysql数据库 105
5.3.5 启动nacos服务 105
5.4 dubbo使用nacos实现注册中心 106
5.5 spring cloud nacos discovery 109
5.5.1 服务端开发 109
5.5.2 消费端开发 113
5.6 nacos实现分析 115
5.6.1 nacos架构图 116
5.6.2 注册中心的 116
5.7 深入解读nacos源码 117
5.7.1 spring cloud什么时候完成服务注册 117
5.7.2 nacosserviceregistry的实现 122
5.7.3 从源码层面分析nacos服务注册的 123
5.7.4 揭秘服务提供者地址查询 127
5.7.5 分析nacos服务地址动态感知 130
5.8 本章小结 132
第6章 nacos实现统一配置管理 133
6.1 nacos配置中心简介 134
6.2 nacos集成spring boot实现统一配置管理 134
6.2.1 项目准备 134
6.2.2 启动nacos server 135
6.2.3 创建配置 135
6.2.4 启动服务并测试 137
6.3 spring cloud nacos config 137
6.3.1 nacos config的基本应用 137
6.3.2 动态更新配置 139
6.3.3 基于data id配置yaml的文件扩展名 140
6.3.4 不同环境的配置切换 141
6.3.5 nacos config自定义namespace和group 142
6.4 nacos config 实现解析 145
6.4.1 配置的crud 145
6.4.2 动态之pull or push 146
6.5 spring cloud如何实现配置的加载 148
6.5.1 propertysourcebootstrapconfiguration 148
6.5.2 propertysourcelocator 150
6.6 nacos config核心源码解析 152
6.6.1 nacosfactory.createconfigservice 154
6.6.2 nacosconfigservice构造 155
6.6.3 clientworker 155
6.6.4 clientworker.checkconfiginfo 157
6.6.5 longpollingrunnable.run 157
6.6.6 服务端长轮询处理机制 161
6.6.7 clientlongpolling 164
6.7 本章小结 167
第7章 基于sentinel的微服务限流及熔断 168
7.1 服务限流的作用及实现 168
7.1.1 计数器算 169
7.1.2 滑动窗算 170
7.1.3 令牌桶限流算 171
7.1.4 漏桶限流算 172
7.2 服务熔断与降级 172
7.3 分布式限流框架sentinel 174
7.3.1 sentinel的特性 174
7.3.2 sentinel的组成 175
7.3.3 sentinel dashboard的部署 175
7.4 sentinel的基本应用 176
7.4.1 sentinel实现限流 176
7.4.2 资源的定义方式 178
7.4.3 sentinel资源保护规则 179
7.4.4 sentinel实现服务熔断 183
7.5 spring cloud集成sentinel实践 185
7.5.1 sentinel接入spring cloud 185
7.5.2 基于sentinel dashboard来实现流控配置 187
7.5.3 自定义url限流异常 189
7.5.4 url资源清洗 189
7.6 sentinel集成nacos实现动态流控规则 190
7.7 sentinel dashboard集成nacos实现规则同步 194
7.7.1 sentinel dashboard源码修改 194
7.7.2 sentinel dashboard规则数据同步 199
7.8 dubbo集成sentinel实现限流 200
7.8.1 dubbo服务接入sentinel dashboard 200
7.8.2 dubbo服务限流规则配置 201
7.9 sentinel热点限流 203
7.9.1 热点参数限流的使用 204
7.9.2 @sentinelresource热点参数限流 205
7.9.3 热点参数规则说明 206
7.10 sentinel的工作 206
7.11 spring cloud sentinel工作分析 207
7.12 sentinel核心源码分析 210
7.12.1 限流的源码实现 210
7.12.2 实时指标数据统计 216
7.12.3 服务降级的实现 225
7.13 本章小结 229
第8章 分布式事务 230
8.1 分布式事务问题的理论模型 231
8.1.1 x/open分布式事务模型 231
8.1.2 两阶段提交协议 233
8.1.3 三阶段提交协议 234
8.1.4 cap定理和base理论 236
8.2 分布式事务问题的常见解决方案 238
8.2.1 tcc补偿型方案 238
8.2.2 基于可靠性消息的终一致性方案 239
8.2.3 优选努力通知型 242
8.3 分布式事务框架seata 243
8.3.1 at模式 243
8.3.2 saga模式 244
8.4 seata的安装 248
8.4.1 file存储模式 248
8.4.2 db存储模式 249
8.4.3 seata服务端配置中心说明 251
8.5 at模式dubbo集成seata 258
8.5.1 项目准备 259
8.5.2 数据库准备 259
8.5.3 核心方说明 260
8.5.4 项目启动顺序及访问 264
8.5.5 整合seata实现分布式事务 265
8.6 spring cloud seata 269
8.6.1 spring cloud项目准备 270
8.6.2 集成spring cloud seata 270
8.6.3 关于事务分组的说明 275
8.7 seata at模式的实现 276
8.7.1 at模式阶段的实现 277
8.7.2 at模式第二阶段的分析 279
8.7.3 关于事务的隔离性保证 280
8.8 本章小结 283
第9章 rocketmq分布式消息通信 285
9.1 什么是rocketmq 285
9.1.1 rocketmq的应用场景 286
9.1.2 rocketmq的安装 286
9.1.3 rocketmq如何发送消息 287
9.1.4 rocketmq如何消费消息 289
9.2 spring cloud rocketmq 291
9.2.1 spring cloud rocketmq架构图 293
9.2.2 spring cloud stream消息发送流程 294
9.2.3 rocketmq binder集成消息发送 299
9.2.4 rocketmq binder集成消息订阅 303
9.2.5 spring cloud stream消息订阅流程 308
9.3 rocketmq集群管理 314
9.3.1 整体架构设计 314
9.3.2 基本概念 315
9.3.3 为什么放弃zookeeper而选择nameserver 316
9.4 如何实现顺序消息 318
9.4.1 顺序消息的使用场景 318
9.4.2 如何发送和消费顺序消息 319
9.4.3 顺序发送的技术 321
9.4.4 普通发送的技术 322
9.4.5 顺序消费的技术 324
9.4.6 并发消费的技术 325
9.4.7 消息的幂等性 325
9.5 如何实现事务消息 326
9.5.1 事务消息的使用场景 326
9.5.2 如何发送事务消息 327
9.5.3 事务消息的技术 330
9.6 高性能设计 331
9.6.1 顺序写盘 333
9.6.2 消费队列设计 334
9.6.3 消息跳跃读取 336
9.6.4 数据零拷贝 336
9.6.5 动态伸缩能力 336
9.6.6 消息实时投递 337
9.7 高可用设计 338
9.7.1 消息发送重试机制 339
9.7.2 故障规避机制 340
9.7.3 同步刷盘与异步刷盘 343
9.7.4 主从复制 350
9.7.5 读写分离 351
9.7.6 消费重试机制 351
9.7.7 ack机制 352
9.7.8 broker集群部署 352
9.8 本章小结 353
0章 微服务网关之spring cloud gateway 354
10.1 api网关的作用 355
10.1.1 统一认证鉴权 356
10.1.2 灰度发布 357
10.2 网关的本质及技术选型 358
10.2.1 openresty 358
10.2.2 spring cloud zuul 360
10.2.3 spring cloud gateway 361
10.3 spring cloud gateway网关实战 361
10.3.1 spring-cloud-gateway-service 361
10.3.2 spring-cloud-gateway-sample 362
10.4 spring cloud gateway分析 363
10.5 route predicate factories 364
10.5.1 指定时间规则匹配路由 365
10.5.2 cookie匹配路由 365
10.5.3 header匹配路由 366
10.5.4 host匹配路由 366
10.5.5 请求方匹配路由 367
10.5.6 请求路径匹配路由 367
10.6 gateway filter factories 367
10.6.1 gatewayfilter 368
10.6.2 globalfilter 372
10.7 自定义过滤器 375
10.7.1 自定义gatewayfilter 375
10.7.2 自定义globalfilter 377
10.8 spring cloud gateway集成nacos实现请求负载 378
10.9 spring cloud gateway集成sentinel网关限流 381
10.9.1 route维度限流 382
10.9.2 自定义api分组限流 384
10.9.3 自定义异常 386
10.9.4 网关流控控制台 387
10.9.5 网关限流 388
10.10 本章小结 389

内容简介

本书针对spring cloud 生态下的技术组件从应用到行全面的分析,涉及的技术组件包括分布式服务治理dubbo、服务配置和服务注册中心nacos、分布式限流与熔断sentinel、分布式消息通信rocketmq、分布式事务seata及微服务网关spring cloud gateway。由于spring cloud中所有的技术组件都是基于spring boot微服务框架来集成的,所以对于spring boot的核心也做了比较详细的分析。本书中涉及的所有技术组件,笔者都采用“场景→需求→解决方案→应用→”高效技术学模型行设计,以便让读者知其然且知其所以然。在“”部分,笔者采用大量的源码及图形的方式来行分析,帮助读者达到对技术组件深度学和理解的目标。

精彩书评

"spring cloud 于2019年8月开源以来,受到了靠前诸多企业和开发者的青睐,但是市面上缺少对其系统性介绍的相关图书。本书作者结合其多年来对互联网技术及微服务架构的理解和实践经验,从入门示例、剖析和源码分析等各个方面整理了每个模块的知识。无论你是刚入门的java开发者,还是从事开发工作多年的码农,本书都能让你受益匪浅。——汤陈 阿里巴巴不错开发工程师spring cloud 的优势绝不仅仅在于“更服靠前的水土”,更在于其脱胎于内部中间件、在多年海量业务场景下打磨出的微服务生态组件,其技术含量与成熟度在优选范围内也极具竞争力。本书作者谭锋在微服务方备丰富的实战经验,并不断将自己的所学所想分享给职场小伙伴们。本书是他的实战经验结,值得阅读。——李嘉鹏(你假笨/寒泉子) perfma ceo我与mic⽼师既是⽼同事,也是⽼朋友。从他的⾝上,我很明显地感受到他已经从⼀位⼤⽜架构师,变成了⼀位“不但能讲⼈话”、还能“授⼈以渔”的很好讲师。本书的⽬录编排、讲述⽅式,深谙程序员所求。对“实⽤主义者”,它直接“show you the code”;对“底层探究者”,它又会阶地补充⼀些性的内容,以加深理解。⽆论你是spring cloud 的初学者,还是正在团队推动技术转型的“老鸟”,这本书都能为你提供很好的帮助,减小你“踩坑”的概率。——顾冬煜 赋优信息技术cto,沪江网前技术监微服务已经在靠前技术圈风靡多时,但能够紧跟时代步伐“知其然又知其所以然”的人不多,能够从“教”“学”“用”多个视角剖析和实践的人则更少。作者既有十多年一线实践经验,又有在教育行业创业与教学的多年经历,相信可以带领大家领略到spring cloud 微服务体系的“精彩”与“拍案”。——王福强 阿里巴巴架构师,canal产品技术奠基人,《spring揭秘》《spring boot揭秘》《深度思考揭秘》《极简管理课》作者作者深耕java十余年,熟悉微服务和分布式系统中的常用技术,本书是他的经验结和汇,循序渐地向我们展示了微服务架构中涉及的核心技术和实现,是学微服务架构与分布式系统技术的书籍。——加多 《java并发编程之美》作者,公众号“技术原始积累”作者"