SOA与REST:用REST构建企业级SOA解决方案

978-7-115-33194-6
作者: 【美】Thomas Erl Benjamin CarlyleCesare Pautasso Raj Balasubramanian
译者: 刘蕊马国耀申健
编辑: 杨海玲

图书目录:

目 录

第 1章 介绍 1

1.1 关于本书 2

1.1.1 本书的目标读者 2

1.1.2 本书不会覆盖的内容 2

1.2 推荐阅读 3

1.3 本书的组织方式 3

1.3.1 第 一部分:基础知识 4

1.3.2 第 二部分:REST风格的面向服务 4

1.3.3 第三部分:REST环境下面向服务的分析与设计 4

1.3.4 第四部分:REST服务组合 5

1.3.5 第五部分:补充 5

1.3.6 第六部分:附录 6

1.4 约定 6

1.4.1 灰色的使用 6

1.4.2 设计约束、原则和模式:页码参考 7

1.4.3 设计目标 7

1.4.4 符号图例 8

1.5 附加信息 8

1.5.1 更新、勘误和资源 8

1.5.2 主词汇表 8

1.5.3 面向服务 8

1.5.4 什么是REST 8

1.5.5 引用的规范 8

1.5.6 服务技术杂志 9

1.5.7 SOASchool.com SOA认证专家(SOACP) 9

1.5.8 CloudSchool.com云认证(CCP)专家 9

1.5.9 通知服务 9

第 2章 案例研究背景 11

2.1 如何使用案例研究 12

2.2 案例研究背景之一:中西部大学联盟(MUA) 12

2.2.1 历史 13

2.2.2 IT环境 13

2.2.3 业务目标和障碍 14

2.3 案例研究背景之二:KioskEtc有限公司 15

2.3.1 历史 15

2.3.2 IT环境 15

2.3.3 业务目标和障碍 16

第 一部分 基础知识

第3章 服务简介 19

3.1 服务术语 20

3.1.1 服务 20

3.1.2 服务契约 20

3.1.3 服务能力 21

3.1.4 服务消费者 21

3.1.5 服务代理 22

3.1.6 服务组装 22

3.2 服务术语上下文 24

3.2.1 服务和REST 24

3.2.2 服务和SOA 24

3.2.3 REST服务和SOA 24

第4章 SOA术语和概念 27

4.1 基本术语和概念 28

4.1.1 面向服务的计算 28

4.1.2 面向服务 29

4.1.3 面向服务架构(SOA) 32

4.1.4 SOA宣言 33

4.1.5 服务 33

4.1.6 云计算 34

4.1.7 IT资源 34

4.1.8 服务模型 34

4.1.9 服务目录 35

4.1.10 服务集 36

4.1.11 候选服务 36

4.1.12 服务契约 36

4.1.13 与服务相关的粒度 37

4.1.14 服务概要 38

4.1.15 SOA设计模式 39

4.2 扩展阅读 40

第5章 REST约束和目标 43

5.1 REST约束 44

5.1.1 客户机-服务器 44

5.1.2 无状态 45

5.1.3 缓存 46

5.1.4 接口/统一契约 46

5.1.5 分层系统 47

5.1.6 随需应变代码 47

5.2 REST架构风格的目标 48

5.2.1 性能 48

5.2.2 可伸缩性 49

5.2.3 简单性 50

5.2.4 可修改性 50

5.2.5 可视性 50

5.2.6 可移植性 51

5.2.7 可靠性 51

第 二部分 REST风格的面向服务

第6章 REST服务契约 55

6.1 统一契约元素 56

6.1.1 资源标识符语法 56

6.1.2 方法 58

6.1.3 媒体类型 60

6.2 REST服务能力和REST服务契约 61

6.3 REST服务契约与非REST服务契约 62

6.3.1 带有定制服务契约的非REST服务 62

6.3.2 REST服务与统一契约 64

6.3.3 HTTP消息传输与SOAP消息传输之比较 65

6.3.4 REST服务契约与WSDL的结合? 66

6.4 超媒体角色 66

6.5 REST服务契约和后期绑定 69

第7章 用REST实现面向服务 73

7.1 “SOA或REST”还是“SOA与REST”? 74

7.2 设计目标 76

7.2.1 提升内在互操作性 76

7.2.2 增强联邦 76

7.2.3 提升厂商选择多样性 77

7.2.4 提升业务与技术对齐 77

7.2.6 提升组织敏捷性 79

7.2.7 降低IT负担 79

7.2.8 通用目标 80

7.3 设计原则与约束 80

7.3.1 标准化服务契约 80

7.3.2 服务松耦合 81

7.3.3 服务抽象 82

7.3.4 服务可重用性 83

7.3.5 服务自治 84

7.3.6 服务无状态 85

7.3.7 服务可发现性 85

7.3.8 服务可组合性 86

7.3.9 常见冲突 86

第三部分 REST环境下面向服务的分析与设计

第8章 主流SOA方法论和REST 95

8.1 服务目录分析 97

8.2 面向服务的分析(服务建模) 98

8.3 面向服务的设计(服务契约) 100

8.4 服务逻辑设计 101

8.5 服务发现 101

8.6 服务版本控制和退役 101

第9章 REST服务分析与服务建模 103

9.1 统一契约建模和REST服务目录建模 104

9.1.1 REST约束和统一契约建模 106

9.1.2 REST服务集中化和规范化 107

9.2 REST服务建模 108

9.2.1 REST服务能力粒度 109

9.2.2 资源与实体 110

9.2.3 REST服务建模流程 110

9.2.4 第 1步:分解业务流程(分解为细粒度活动) 113

9.2.5 第 2步:过滤掉不适合的活动 113

9.2.6 第3步:识别无关性候选服务 114

9.2.7 第4步:识别特定于流程的逻辑 117

9.2.8 第5步:识别资源 118

9.2.9 第6步:将服务能力与方法和资源相关联 119

9.2.10 第7步:应用面向服务 121

9.2.11 第8步:识别候选服务组合 122

9.2.12 第9步:分析流程处理需求 123

9.2.13 第 10步:定义候选公用服务 124

9.2.14 第 11步:将以公用功能为中心的服务能力与方法和资源相关联 124

9.2.15 第 12步:应用面向服务 124

9.2.16 第 13步:修改候选服务组合 125

9.2.17 第 14步:修改资源定义 125

9.2.18 第 15步:修改候选能力分组 125

9.2.19 其他考虑因素 125

第 10章 面向服务的设计和REST 127

10.1 统一契约设计考虑 128

10.1.1 设计并标准化方法 129

10.1.2 设计HTTP头并进行标准化 130

10.1.3 设计HTTP响应代码并进行标准化 131

10.1.4 设计媒体类型 135

10.1.5 设计媒体类型模式 136

10.2 REST服务契约设计 138

10.2.1 基于服务模型设计服务 138

10.2.2 设计资源标识符并进行标准化 141

10.2.3 在REST约束下设计及REST约束的标准化 145

10.3 复杂方法的设计 152

10.3.1 无状态的复杂方法 154

10.3.2 有状态的复杂方法 159

第四部分 REST服务组合

第 11章 REST基础服务组合 167

11.1 服务组合术语 168

11.1.1 组合和组合实例 168

11.1.2 组合成员和控制器 169

11.1.3 服务活动 172

11.1.4 组合启动者 173

11.1.5 点对点数据交换和组合 173

11.2 服务组合的设计影响 174

11.2.1 面向服务原则和组合设计 174

11.2.2 REST约束和组合设计 177

11.3 组合层次结构和分层 178

11.3.1 实体服务组成任务服务 179

11.3.2 实体服务组成实体服务 180

11.4 REST服务组合设计的若干考虑 181

11.4.1 同步和异步服务组合 181

11.4.2 幂等的服务活动 182

11.4.3 组合的逗留状态 182

11.4.4 组合参与者之间的绑定 183

11.5 按步骤分解的服务活动 184

11.5.1 请求购买机票 184

11.5.2 验证所请求的航班详情 185

11.5.3 确认航班座位 185

11.5.4 生成单据 185

11.5.5 创建机票 185

11.5.6 总结 186

第 12章 REST高 级服务组合 187

12.1 服务组合与无状态 189

12.1.1 采用服务无状态的组合设计 189

12.1.2 采用无状态的组合设计 189

12.2 跨服务的REST事务 190

12.2.1 REST友好的原子服务事务 190

12.2.2 REST友好的补偿服务事务 194

12.2.3 非REST友好的原子服务事务 197

12.3 事件驱动的REST交互 200

12.3.1 事件驱动的消息机制 200

12.3.2 消息轮询 201

12.4 带有动态绑定和逻辑延迟的服务组合 204

12.4.1 跨规范化服务的非规范化能力 204

12.4.2 深化组合 207

12.4.3 动态地绑定公共属性 208

12.4.4 运行时逻辑延迟 210

12.5 跨服务目录的服务组合 211

12.5.1 REST的目录端点 211

12.5.2 基线标准化的服务目录之间的动态绑定 213

第 13章 REST服务组合之案例研究 215

13.1 重温授予学生奖项流程 216

13.2 提交申请和任务服务调用 218

13.3 授予学生奖项服务组合实例(评审前的服务活动视图) 219

13.3.1 步骤1:从组合启动者到授予学生奖项任务服务(A) 220

13.3.2 步骤2:从授予学生奖项任务服务到事迹实体服务(B) 220

13.3.3 步骤3:从事迹实体服务到授予学生奖项任务服务(B) 220

13.3.4 步骤4:从授予学生奖项任务服务到奖项实体服务(E) 221

13.3.5 步骤5:从奖项实体服务到授予学生奖项任务服务(E) 221

13.3.6 步骤6:从授予学生奖项任务服务到奖项实体服务(E) 221

13.3.7 步骤7:从奖项实体服务到授予学生奖项任务服务(E) 221

13.3.8 步骤8:从授予学生奖项任务服务到学生实体服务(F) 222

13.3.9 步骤9:从学生实体服务到授予学生奖项任务服务(F) 222

13.3.10 步骤10:从授予学生奖项任务服务到学生成绩单实体服务(F) 222

13.3.11 步骤11:从学生成绩单实体服务到授予学生奖项任务服务(F) 222

13.3.12 步骤12:从授予学生奖项任务服务到组合启动者(A) 223

13.4 评审待定的申请和任务服务调用 223

13.5 授予学生奖项服务组合实例(评审后的服务活动视图) 224

13.5.1 步骤1:从组合启动者到授予学生奖项任务服务(L) 225

13.5.2 步骤2:从授予学生奖项任务服务到通知公用服务(N) 225

13.5.3 步骤3:从通知公用服务到学生实体服务(N) 225

13.5.4 步骤4:从学生实体服务到通知公用服务(N) 225

13.5.5 步骤5:从通知公用服务到授予学生奖项任务服务(N) 226

13.5.6 中间步骤:从授予学生奖项任务服务到事务协调者(P,Q) 226

13.5.7 中间步骤:从事务协调者到授予学生奖项任务服务(P,Q) 226

13.5.8 步骤6:从授予学生奖项任务服务到授予实体服务(P) 226

13.5.9 中间步骤:从授予实体服务到事务协调者(P) 226

13.5.10 中间步骤:从事务协调者到授予实体服务(P) 227

13.5.11 步骤7:从授予实体服务到授予学生奖项任务服务(Q) 227

13.5.12 步骤8:从授予学生奖项任务服务到学生成绩单实体服务(Q) 227

13.5.13 中间步骤:从学生成绩单实体服务到事务协调者(Q) 227

13.5.14 中间步骤:从事务协调者到学生成绩单实体服务(Q) 227

13.5.15 步骤9:从学生成绩单实体服务到授予学生奖项任务服务(Q) 227

13.5.16 中间步骤:从授予学生奖项任务服务到事务协调者(P,Q) 228

13.5.17 中间步骤:从事务协调者到授予学生奖项任务服务(P,Q) 228

13.5.18 步骤10:从授予学生奖项任务服务到组合启动者(L) 228

第五部分 补充

第 14章 SOA与REST的设计模式 231

14.1 受REST启发的SOA设计模式 233

14.1.1 内容协商 233

14.1.2 端点重定向 234

14.1.3 实体链接 235

14.1.4 幂等能力 237

14.1.5 轻量级端点 238

14.1.6 可重用契约 239

14.1.7 统一契约 240

14.2 其他相关的SOA设计模式 241

14.2.1 契约集中化 241

14.2.2 契约去规范化 241

14.2.3 域目录 241

14.2.4 模式集中化 241

14.2.5 状态消息机制 242

14.2.6 校验抽象 242

第 15章 REST服务版本控制 243

15.1 版本控制基础 244

15.1.1 REST服务契约的兼容性 245

15.1.2 统一契约方法的兼容性 246

15.1.3 统一契约媒体类型的兼容性 247

15.2 版本标识符 250

15.2.1 使用版本标识符 251

15.2.2 版本标识符和统一契约 252

第 16章 统一契约概要 255

16.1 统一契约概要模板 256

16.1.1 统一契约层结构 256

16.1.2 方法概要结构 257

16.1.3 媒体类型概要结构 258

16.2 REST服务概要考虑 259

第六部分 附录

附录A 案例研究结论 269

附录B 支持Web的工业标准 273

附录C REST约束参考 277

附录D 面向服务原则参考 285

附录E SOA设计模式参考 291

附录F 状态的概念和类型 327

附录G 带注解的SOA宣言 337

附录H 其他资源 347

书中提到的模式的作者 352

关于序的作者 352

关于作者 353

详情

本书深入介绍了 SOA与 REST的原理、术语及特性;深入阐述了二者之间的差异及合作点;重点阐述了如何将 REST作为媒介来实现 SOA的战略目标,通过对 REST服务的建模流程和专为 REST服务定制的面向服务的分析和设计流程的详细讲解,逐步向读者展开了一幅 REST与 SOA在企业级解决方案中完美“联姻”的画卷。此外,本书还通过完整的案例研究示例展示了 REST与 SOA在实践中的结合。

图书摘要

相关图书

DirectX 12 3D 游戏开发实战
DirectX 12 3D 游戏开发实战
Python和NLTK自然语言处理
Python和NLTK自然语言处理
scikit-learn机器学习(第2版)
scikit-learn机器学习(第2版)
C++编程自学宝典
C++编程自学宝典
数据科学实战手册(第2版)
数据科学实战手册(第2版)
Scala实用指南
Scala实用指南

相关文章

相关课程