“免费”赠送Spring微服务实战书籍,快来领呀~

本书适合拥有构建分布式应用程序的经验、拥有Spring的知识背景以及对学习构建基于微服务的应用程序感兴趣的Java开发人员阅读。

本书籍赠送活动详情,请识别上图二维码☝☝☝☝☝

书籍推荐

本书教读者如何使用Java和Spring平台构建基于微服务的应用程序。在构建和部署dy个Spring Cloud应用程序时,读者将学习如何进行微服务设计。在本书中,

精心挑选的真实案例展示了基于微服务的各种模式,这些模式用于配置、路由、扩展和部署服务。读者将了解Spring易于使用的工具,并看到其如何助力用微服务

来增强和重构现有的应用程序。

本书主要内容

● 核心微服务设计原则。

● 使用Spring Cloud Config管理配置。

● 使用Spring、Hystrix和Ribbon实现客户端弹性。

● 使用Netflix Zuul进行智能路由。

● 部署Spring Cloud应用程序。

本书是为具有Java和Spring经验的开发人员编写的。

目录

第 1章 欢迎迈入云世界,Spring 1

1.1 什么是微服务 1

1.2 什么是Spring,为什么它与微服务有关 4

1.3 在本书中读者会学到什么 5

1.4 为什么本书与你有关 6

1.5 使用Spring Boot来构建微服务 6

1.6 为什么要改变构建应用的方式 10

1.7 云到底是什么 11

1.8 为什么是云和微服务 13

1.9 微服务不只是编写代码 14

1.9.1 核心微服务开发模式 15

1.9.2 微服务路由模式 16

1.9.3 微服务客户端弹性模式 17

1.9.4 微服务安全模式 18

1.9.5 微服务日志记录和跟踪模式 19

1.9.6 微服务构建和部署模式 20

1.10 使用Spring Cloud构建微服务 22

1.10.1 Spring Boot 23

1.10.2 Spring Cloud Config 23

1.10.3 Spring Cloud服务发现 24

1.10.4 Spring Cloud与Netflix Hystrix和Netflix Ribbon 24

1.10.5 Spring Cloud与Netflix Zuul 24

1.10.6 Spring Cloud Stream 24

1.10.7 Spring Cloud Sleuth 24

1.10.8 Spring Cloud Security 25

1.10.9 代码供应 25

1.11 通过示例来介绍Spring Cloud 25

1.12 确保本书的示例是有意义的 27

1.13 小结 28

第 2章 使用Spring Boot构建微服务 29

2.1 架构师的故事:设计微服务架构 31

2.1.1 分解业务问题 31

2.1.2 建立服务粒度 32

2.1.3 互相交流:定义服务接口 35

2.2 何时不应该使用微服务 36

2.2.1 构建分布式系统的复杂性 36

2.2.2 服务器散乱 36

2.2.3 应用程序的类型 36

2.2.4 数据事务和一致性 37

2.3 开发人员的故事:用SpringBoot和Java构建微服务 37

2.3.1 从骨架项目开始 37

2.3.2 引导Spring Boot应用程序:编写引导类 39

2.3.3 构建微服务的入口:Spring Boot控制器 40

2.4 DevOps工程师的故事:构建运行时的严谨性 44

2.4.1 服务装配:打包和部署微服务 46

2.4.2 服务引导:管理微服务的配置 47

2.4.3 服务注册和发现:客户端如何与微服务通信 48

2.4.4 传达微服务的“健康状况” 49

2.5 将视角综合起来 51

2.6 小结 52

第3章 使用Spring Cloud配置服务器控制配置 53

3.1 管理配置(和复杂性) 54

3.1.1 配置管理架构 55

3.1.2 实施选择 56

3.2 构建Spring Cloud配置服务器 58

3.2.1 创建Spring Cloud Config引导类 61

3.2.2 使用带有文件系统的Spring Cloud配置服务器 62

3.3 将Spring Cloud Config与Spring Boot客户端集成 64

3.3.1 建立许可证服务对Spring Cloud Config服务器的依赖 65

3.3.2 配置许可证服务以使用Spring Cloud Config 66

3.3.3 使用Spring Cloud配置服务器连接数据源 69

3.3.4 使用@Value注解直接读取属性 72

3.3.5 使用Spring Cloud配置服务器和Git 73

3.3.6 使用Spring Cloud配置服务器刷新属性 73

3.4 保护敏感的配置信息 75

3.4.1 下载并安装加密所需的Oracle JCE jar 75

3.4.2 创建加密密钥 76

3.4.3 加密和解密属性 76

3.4.4 配置微服务以在客户端使用加密 78

3.5  后的想法 79

3.6 小结 80

第4章 服务发现 81

4.1 我的服务在哪里 82

4.2 云中的服务发现 84

4.2.1 服务发现架构 84

4.2.2 使用Spring和Netflix Eureka进行服务发现实战 87

4.3 构建Spring Eureka服务 88

4.4 通过Spring Eureka注册服务 90

4.5 使用服务发现来查找服务 93

4.5.1 使用Spring DiscoveryClient查找服务实例 95

4.5.2 使用带有Ribbon功能的Spring RestTemplate调用服务 97

4.5.3 使用Netflix Feign客户端调用服务 98

4.6 小结 100

第5章 使用Spring Cloud和NetflixHystrix的客户端弹性模式 101

5.1 什么是客户端弹性模式 102

5.1.1 客户端负载均衡模式 103

5.1.2 断路器模式 103

5.1.3 后备模式 103

5.1.4 舱壁模式 104

5.2 为什么客户端弹性很重要 104

5.3 进入Hystrix 107

5.4 搭建许可服务器以使用Spring Cloud和Hystrix 107

5.5 使用Hystrix实现断路器 109

5.5.1 对组织微服务的调用超时 111

5.5.2 定制断路器的超时时间 112

5.6 后备处理 113

5.7 实现舱壁模式 115

5.8 基础进阶—微调Hystrix 118

5.9 线程上下文和Hystrix 122

5.9.1 ThreadLocal与Hystrix 122

5.9.2 HystrixConcurrencyStrategy实战 125

5.10 小结 129

第6章 使用Spring Cloud和Zuul进行服务路由 131

6.1 什么是服务网关 132

6.2 Spring Cloud和Netflix Zuul简介 133

6.2.1 建立一个Zuul Spring Boot项目 134

6.2.2 为Zuul服务使用Spring Cloud注解 134

6.2.3 配置Zuul与Eureka进行通信 135

6.3 在Zuul中配置路由 135

6.3.1 通过服务发现自动映射路由 136

6.3.2 使用服务发现手动映射路由 137

6.3.3 使用静态URL手动映射路由 140

6.3.4 动态重新加载路由配置 142

6.3.5 Zuul和服务超时 143

6.4 Zuul的真正威力:过滤器 144

6.5 构建 个生成关联ID的Zuul前置过滤器 147

6.6 构建接收关联ID的后置过滤器 155

6.7 构建动态路由过滤器 157

6.7.1 构建路由过滤器的骨架 159

6.7.2 实现run()方法 159

6.7.3 转发路由 161

6.7.4 整合 162

6.8 小结 163

第7章 保护微服务 164

7.1 OAuth2简介 165

7.2 从小事做起:使用Spring和OAuth2来保护单个端点 167

7.2.1 建立EagleEye OAuth2验证服务 167

7.2.2 使用OAuth2服务注册客户端应用程序 168

7.2.3 配置EagleEye用户 171

7.2.4 验证用户 172

7.3 使用OAuth2保护组织服务 175

7.3.1 将Spring Security和OAuth2 jar添加到各个服务 176

7.3.2 配置服务以指向OAuth2验证服务 176

7.3.3 定义谁可以访问服务 177

7.3.4 传播OAuth2访问令牌 180

7.4 JSON Web Token与OAuth2 183

7.4.1 修改验证服务以颁发JWT令牌 184

7.4.2 在微服务中使用JWT 188

7.4.3 扩展JWT令牌 189

7.4.4 从JWT令牌中解析自定义字段 191

7.5 关于微服务安全的总结 193

7.6 小结 195

第8章 使用Spring Cloud Stream的事件驱动架构 196

8.1 为什么使用消息传递、EDA和微服务 197

8.1.1 使用同步请求-响应方式来传达状态变化 198

8.1.2 使用消息传递在服务之间传达状态更改 199

8.1.3 消息传递架构的缺点 201

8.2 Spring Cloud Stream简介 202

8.3 编写简单的消息生产者和消费者 205

8.3.1 在组织服务中编写消息生产者 205

8.3.2 在许可证服务中编写消息消费者 210

8.3.3 在实际操作中查看消息服务 213

8.4 Spring Cloud Stream用例:分布式缓存 214

8.4.1 使用Redis来缓存查找 215

8.4.2 定义自定义通道 221

8.4.3 将其全部汇集在一起:在收到消息时清除缓存 222

8.5 小结 223

第9章 使用Spring Cloud Sleuth和Zipkin进行分布式跟踪 224

9.1 Spring Cloud Sleuth与关联ID 225

9.1.1 将Spring Cloud Sleuth添加到许可证服务和组织服务中 226

9.1.2 剖析Spring Cloud Sleuth跟踪 226

9.2 日志聚合与Spring Cloud Sleuth 227

9.2.1 Spring Cloud Sleuth与Papertrail实现实战 229

9.2.2 创建Papertrail账户并配置syslog连接器 230

9.2.3 将Docker输出重定向到Papertrail 232

9.2.4 在Papertrail中搜索Spring Cloud Sleuth的跟踪ID 234

9.2.5 使用Zuul将关联ID添加到HTTP响应 235

9.3 使用Open Zipkin进行分布式跟踪 237

9.3.1 添加Spring Cloud Sleuth和Zipkin依赖项 238

9.3.2 配置服务以指向Zipkin 238

9.3.3 安装和配置Zipkin服务器 239

9.3.4 设置跟踪级别 240

9.3.5 使用Zipkin跟踪事务 241

9.3.6 可视化更复杂的事务 243

9.3.7 捕获消息传递跟踪 244

9.3.8 添加自定义跨度 246

9.4 小结 248

第 10章 部署微服务 250

10.1 EagleEye:在云中建立核心基础设施 251

10.1.1 使用 的RDS创建PostgreSQL数据库 253

10.1.2 在AWS中创建Redis集群 257

10.1.3 创建ECS集群 258

10.2  基础设施:部署EagleEye 262

10.3 构建和部署管道的架构 265

10.4 构建和部署管道实战 268

10.5 开始构建和部署管道:GitHub和Travis CI 270

10.6 使服务能够在Travis CI中构建 270

10.6.1 构建的核心运行时配置 273

10.6.2 安装预构建工具 275

10.6.3 执行构建 277

10.6.4 标记源代码 277

10.6.5 构建微服务并创建Docker镜像 279

10.6.6 将镜像推送到Docker Hub 279

10.6.7 在Amazon ECS中启动服务 280

10.6.8 启动平台测试 280

10.7 关于构建和部署管道的总结 282

10.8 小结 282

附录A 在桌面运行云服务 283

附录B OAuth2授权类型 291

关注公众号:程序员生态圈,公众号后续会有其他书籍赠送活动,大家需要什么书籍的,可以在评论区留言

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • 前言 现在研发的项目启动今已近一年之久,期间从项目属性、人员规模、系统定位等方面都发生了很大的变化,而且是越变越好...
    孙振强阅读 12,292评论 1 58
  • 那个让你对明天有所期待的人, 根本就没能出现在你的明天里。
    你是幸运的周杰阅读 166评论 0 2
  • 哟, 你好吗? 谈谈这些日子的感受吧。 我本身是一个很懒的天秤座, 不善于华丽辞藻,不善于长篇大论。 不是在发现新...
    莫芮阅读 214评论 0 2
  • 小时候妈妈爸爸要忙工作,总是一个人在家。害怕与孤单陪伴了我大半的童年时光,也许从那时候慢慢习惯了孤独,长大...
    一棵树H阅读 216评论 0 0
  • 代码:如果加在局部,可以在前面加上类 效果:
    LuckyJin阅读 195评论 0 0