第1章 Spring Cloud概述 1
1.1 传统的应用 2
1.1.1 单体应用 2
1.1.2 架构演进 3
1.1.3 架构要求 4
1.2 微服务与Spring Cloud 5
1.2.1 什么是微服务 5
1.2.2 关于Netflix OSS 6
1.2.3 Spring Cloud与Netflix 6
1.2.4 Spring Cloud的主要模块 6
1.3 学习方面的准备工作 7
1.3.1 下载本书的软件及源码 7
1.3.2 导入本书的案例 7
1.4 本章小结 8
第2章 搭建开发环境 9
2.1 安装与配置Maven 10
2.1.1 关于Maven 10
2.1.2 下载与安装Maven 11
2.1.3 配置远程仓库 11
2.2 安装Eclipse 12
2.2.1 Eclipse版本 12
2.2.2 在Eclipse中配置Maven 12
2.3 Spring Boot 13
2.3.1 Spring Boot简介 13
2.3.2 新建Maven项目 14
2.3.3 编写启动类 15
2.3.4 编写控制器 16
2.3.5 发布REST WebService 17
2.4 Spring Boot配置文件 18
2.4.1 默认配置文件 18
2.4.2 指定配置文件位置 19
2.4.3 yml文件 19
2.4.4 运行时指定profiles配置 20
2.4.5 热部署 20
2.5 Spring Cloud的版本 21
2.6 本章小结 21
第3章 微服务发布与调用 22
3.1 Eureka介绍 23
3.1.1 关于Eureka 23
3.1.2 Eureka架构 23
3.1.3 服务器端 24
3.1.4 服务提供者 24
3.1.5 服务调用者 24
3.2 第一个Eureka应用 24
3.2.1 构建服务器 24
3.2.2 服务器注册开关 27
3.2.3 编写服务提供者 27
3.2.4 编写服务调用者 29
3.2.5 程序结构 32
3.3 Eureka集群搭建 33
3.3.1 本例集群结构图 33
3.3.2 改造服务器端 34
3.3.3 改造服务提供者 35
3.3.4 改造服务调用者 37
3.3.5 编写REST客户端进行测试 37
3.4 服务实例的健康自检 38
3.4.1 程序结构 39
3.4.2 使用Spring Boot Actuator 39
3.4.3 实现应用健康自检 39
3.4.4 服务查询 42
3.5 Eureka的常用配置 44
3.5.1 心跳检测配置 44
3.5.2 注册表抓取间隔 44
3.5.3 配置与使用元数据 45
3.5.4 自我保护模式 45
3.6 本章小结 46
第4章 负载均衡 47
4.1 Ribbon介绍 48
4.1.1 Ribbon简介 48
4.1.2 Ribbon子模块 48
4.1.3 负载均衡器组件 48
4.2 第一个Ribbon程序 49
4.2.1 编写服务 49
4.2.2 编写请求客户端 51
4.2.3 Ribbon的配置 52
4.3 Ribbon的负载均衡机制 53
4.3.1 负载均衡器 53
4.3.2 自定义负载规则 54
4.3.3 Ribbon自带的负载规则 56
4.3.4 Ping机制 57
4.3.5 自定义Ping 59
4.3.6 其他配置 59
4.4 在Spring Cloud中使用Ribbon 60
4.4.1 准备工作 60
4.4.2 使用代码配置Ribbon 61
4.4.3 使用配置文件设置Ribbon 63
4.4.4 Spring使用Ribbon的API 64
4.5 RestTemplate负载均衡 66
4.5.1 @LoadBalanced注解概述 66
4.5.2 编写自定义注解以及拦截器 66
4.5.3 使用自定义拦截器以及注解 68
4.5.4 在控制器中使用RestTemplate 69
4.6 本章小结 71
第5章 REST客户端Feign 72
5.1 REST客户端 73
5.1.1 使用CXF调用REST服务 73
5.1.2 使用Restlet调用REST服务 74
5.1.3 Feign框架介绍 75
5.1.4 第一个Feign程序 76
5.1.5 请求参数与返回对象 77
5.2 使用Feign 78
5.2.1 编码器 79
5.2.2 解码器 80
5.2.3 XML的编码与解码 80
5.2.4 自定义编码器与解码器 83
5.2.5 自定义Feign客户端 83
5.2.6 使用第三方注解 85
5.2.7 Feign解析第三方注解 86
5.2.8 请求拦截器 89
5.2.9 接口日志 89
5.3 在Spring Cloud中使用Feign 90
5.3.1 Spring Cloud整合Feign 91
5.3.2 Feign负载均衡 93
5.3.3 默认配置 93
5.3.4 自定义配置 94
5.3.5 可选配置 97
5.3.6 压缩配置 98
5.4 本章小结 98
第6章 Spring Cloud的保护机制 99
6.1 概述 100
6.1.1 实际问题 100
6.1.2 传统的解决方式 101
6.1.3 集群容错框架Hystrix 101
6.1.4 Hystrix的功能 102
6.2 第一个Hystrix程序 103
6.2.1 准备工作 103
6.2.2 客户端使用Hystrix 103
6.2.3 调用错误服务 105
6.2.4 Hystrix的运作流程 106
6.3 Hystrix的使用 108
6.3.1 命令执行 108
6.3.2 属性配置 110
6.3.3 回退 111
6.3.4 回退的模式 112
6.3.5 断路器开启 113
6.3.6 断路器关闭 116
6.3.7 隔离机制 118
6.3.8 合并请求 121
6.3.9 请求缓存 125
6.4 在Spring Cloud中使用Hystrix 127
6.4.1 整合Hystrix 128
6.4.2 命令配置 130
6.4.3 默认配置 131
6.4.4 缓存注解 132
6.4.5 合并请求注解 134
6.4.6 Feign与Hystrix整合 136
6.4.7 Hystrix监控 140
6.5 本章小结 142
第7章 微服务集群网关 143
7.1 Zuul框架介绍 144
7.1.1 关于Zuul 144
7.1.2 Zuul的功能 144
7.2 在Web项目中使用Zuul 145
7.2.1 Web项目整合Zuul 145
7.2.2 测试路由功能 145
7.2.3 过滤器运行机制 147
7.3 在微服务集群中初试Zuul 148
7.3.1 集群搭建 149
7.3.2 路由到集群服务 150
7.3.3 Zuul Http客户端 153
7.4 路由配置 153
7.4.1 简单路由 154
7.4.2 跳转路由 155
7.4.3 Ribbon路由 155
7.4.4 自定义路由规则 156
7.4.5 忽略路由 157
7.5 Zuul的其他配置 157
7.5.1 请求头配置 157
7.5.2 路由端点 158
7.5.3 Zuul与Hystrix 158
7.5.4 在Zuul中预加载Ribbon 161
7.6 Zuul功能进阶 161
7.6.1 过滤器优先级 161
7.6.2 自定义过滤器 162
7.6.3 动态加载过滤器 163
7.6.4 禁用过滤器 165
7.6.5 请求上下文 166
7.6.6 @EnableZuulServer注解 168
7.6.7 error过滤器 169
7.6.8 动态路由 171
7.7 本章小结 172
第8章 微服务与消息驱动 173
8.1 Spring Cloud Stream介绍 174
8.1.1 关于Stream框架 174
8.1.2 Stream框架的组成部分 174
8.1.3 消息代理中间件 174
8.2 RabbitMQ框架 175
8.2.1 RabbitMQ和AMQP 175
8.2.2 下载与运行 176
8.2.3 编写生产者 177
8.2.4 编写消费者 179
8.2.5 交换器、绑定与队列 180
8.3 Apache Kafka框架 181
8.3.1 关于Kafka 181
8.3.2 运行Kafka服务器 182
8.3.3 编写生产者 182
8.3.4 编写消费者 184
8.3.5 消费者组 185
8.4 开发消息微服务 185
8.4.1 准备工作 186
8.4.2 编写生产者 187
8.4.3 编写消费者 188
8.4.4 更换绑定器 189
8.4.5 Sink、Source与Processor 190
8.4.6 消费者组 191
8.5 本章小结 192
第9章 集群配置中心 193
9.1 概述 194
9.1.1 关于Spring Cloud Config 194
9.1.2 应用结构 195
9.1.3 引导程序简介 195
9.1.4 搭建SVN环境 196
9.2 构建第一个例子 196
9.2.1 创建服务器 196
9.2.2 配置SVN仓库 197
9.2.3 创建客户端 199
9.2.4 从客户端读取SVN配置 200
9.2.5 目录配置总结 201
9.2.6 刷新配置 202
9.2.7 刷新Bean 203
9.3 配置的加密和解密 205
9.3.1 为服务器安装JCE 205
9.3.2 加密和解密端点 205
9.3.3 SVN存储加密数据 206
9.3.4 非对称加密 207
9.4 其他配置 207
9.4.1 服务器健康指示器 207
9.4.2 客户端的错误提前与重试机制 208
9.4.3 安全配置 209
9.4.4 访问服务器配置 210
9.5 整合使用 210
9.5.1 准备工作 210
9.5.2 配置服务器、客户端整合Eureka 212
9.5.3 整合Zuul 214
9.5.4 整合Spring Cloud Bus刷新配置 216
9.5.5 刷新单个节点配置 217
9.6 本章小结 217
第10章 微服务跟踪 219
10.1 概述 220
10.1.1 实际问题与Sleuth 220
10.1.2 服务跟踪系统 220
10.1.3 Sleuth的基本概念 220
10.1.4 项目准备 221
10.2 Sleuth整合Zipkin 222
10.2.1 Zipkin简介 222
10.2.2 构建Zipkin服务器项目 223
10.2.3 配置微服务 224
10.2.4 查看数据 225
10.2.5 使用MySQL保存数据 228
10.2.6 使用消息采集数据 230
10.3 Sleuth整合ELK 232
10.3.1 关于ELK 232
10.3.2 下载ELK 233
10.3.3 运行Elasticsearch 233
10.3.4 使用Logstash读取JSON 234
10.3.5 使用Kibana展示数据 235
10.3.6 使用Logback转换JSON 237
10.4 本章小结 240
第11章 微服务数据库实战 241
11.1 概述 242
11.1.1 关于Spring Data 242
11.1.2 Spring Data的功能 243
11.1.3 Spring Data的模块 243
11.2 Spring Data与JPA 243
11.2.1 构建项目 244
11.2.2 数据访问层与业务层 245
11.2.3 自定义数据存储逻辑 247
11.2.4 方法名查询 248
11.2.5 使用@Query注解 249
11.3 Spring Data与MongoDB 250
11.3.1 安装MongoDB 250
11.3.2 配置权限 251
11.3.3 MongoDB的概念 252
11.3.4 构建项目 252
11.3.5 数据访问层与业务层 253
11.3.6 自定义数据存储逻辑 254
11.3.7 方法名查询 256
11.3.8 使用@Query注解 258
11.4 Spring Data与Redis 258
11.4.1 Redis的安装与配置 258
11.4.2 Redis的数据类型 259
11.4.3 使用Jedis 260
11.4.4 构建Spring Data项目 262
11.4.5 数据访问层与业务层 263
11.4.6 自定义数据存储逻辑 265
11.4.7 方法名查询 267
11.5 本章小结 268
第12章 案例实战 269
12.1 概述 270
12.1.1 表现层技术 270
12.1.2 案例概述 270
12.1.3 案例技术选型 270
12.2 Spring Boot与JSP 271
12.2.1 构建项目 271
12.2.2 配置 272
12.2.3 打包部署 273
12.3 模板引擎Thymeleaf 274
12.3.1 关于Thymeleaf 274
12.3.2 Spring Boot整合Thymeleaf 274
12.3.3 加载资源 275
12.3.4 获取请求数据 276
12.3.5 调用Bean方法 276
12.3.6 遍历集合 277
12.3.7 表单提交 277
12.4 图书管理案例 278
12.4.1 运行案例 278
12.4.2 案例模块 279
12.4.3 案例架构 279
12.4.4 数据库 280
12.4.5 用户登录 280
12.4.6 新建图书 284
12.4.7 图书展示 286
12.5 本章小结 287
· · · · · · (
收起)