第1章 概述 1
1.1 什么是架构和架构师 1
1.2 这本书是为谁写的 2
1.3 为什么写作此书 3
1.4 通往架构师之路的路线图 5
1.5 架构师应该具备的素质 7
1.6 对架构师的学习和培养过程的几点建议 7
1.7 本书的主要内容 8
1.8 总结 10
第1部分 基础篇 13
第2章 重新看待系统集成 13
2.1 系统集成历史的快速回放 13
2.2 到底什么是系统集成 15
2.2.1 系统集成之信息更新 16
2.2.2 系统集成之信息组合 18
2.2.3 系统集成之连锁行动 19
2.3 系统集成的技术组成部分 24
2.3.1 BUS——高速公路 24
2.3.2 连接器——高速公路的进出口 25
2.3.3 CDM——高速公路运输的集装箱 26
2.3.4 数据转换——运输过程中的货物处理 31
2.4 系统集成应用的考虑 32
2.4.1 系统集成的过程中到底要完成什么任务 32
2.4.2 如何保证系统集成过程中数据传递的可靠性 33
2.4.3 如何使用消息服务器 34
2.5 实战:PLM数据与现有系统的集成 35
2.5.1 项目背景 35
2.5.2 业务痛点 36
2.5.3 技术难点 37
2.5.4 解决方案及经验教训 40
2.6 总结 42
第3章 系统之间相互作用的模式 43
3.1 系统集成模式简介 43
3.2 系统集成模式中几个最重要的概念 48
3.2.1 主题与队列在消息传递中的区别 49
3.2.2 消息服务器所使用的储存-转送 50
3.2.3 消息服务器的容错和高可用性 53
3.2.4 分级式事件驱动架构及其实际应用 55
3.3 系统集成模式的实战应用和分析 58
3.3.1 消息的顺序处理 58
3.3.2 持久订阅如何实现 61
3.3.3 命令类消息的应用 64
3.3.4 事件消息的使用 66
3.3.5 回复地址的使用 67
3.3.6 消息传递搭桥的使用 68
3.3.7 消息信封的使用 72
3.4 总结 73
第4章 常见的参与集成的功能系统 74
4.1 功能系统与集成基础设施的连接 75
4.2 常见功能系统的功能和类型 77
4.3 总结 78
第5章 究竟什么是服务 79
5.1 什么是服务 79
5.2 是谁在推动服务的重复使用 81
5.3 服务的操作 82
5.4 服务的界面 85
5.5 服务操作的粒度 89
5.6 服务的组合——SOA 91
5.7 实战:数据 93
5.7.1 项目背景 93
5.7.2 业务痛点 93
5.7.3 技术难点 93
5.7.4 解决方案及经验教训 94
5.8 总结 95
第6章 系统集成项目的实施步骤 97
6.1 系统集成与服务项目概述 98
6.2 系统集成与服务项目的具体实施步骤 101
6.3 设计和开发阶段 102
6.3.1 搜集项目业务功能要求 102
6.3.2 架构设计 107
6.3.3 细节设计 110
6.3.4 代码编写和单元测试 112
6.3.5 集成测试 114
6.4 测试和验收阶段 114
6.4.1 质量保证(QA)部署 115
6.4.2 质量保证(QA)测试 116
6.4.3 用户验收(UA)部署 116
6.4.4 用户验收测试(UAT) 116
6.4.5 (可选项)操作验收测试(OAT) 117
6.5 运维、培训和交付阶段 117
6.5.1 生产环境部署 117
6.5.2 试运行 117
6.5.3 培训及文档提交 118
6.5.4 项目验收 118
6.6 总结 118
第7章 集成项目与公共服务 119
7.1 公共服务的具体内容 120
7.1.1 日志服务 121
7.1.2 出错处理服务 124
7.1.3 ID映射服务 126
7.1.4 顺序处理服务 128
7.1.5 系统及应用监控服务 129
7.1.6 应用、服务、API的分析服务 131
7.2 业务项目的项目模板及其与公共服务的互动 132
7.3 总结 133
第8章 SOA在实施中的局限性 135
8.1 SOA在具体实施中的做法 136
8.1.1 SOA的设计原则 136
8.1.2 SOA绩优中心 139
8.2 深挖SOA的初衷 142
8.3 SOA的适用范围和局限性 144
8.4 总结 145
第2部分 正篇——现代API、应用互联网 149
第9章 现代API的引入、应用互联网 149
9.1 什么是(现代)API 149
9.1.1 REST架构的特点 151
9.1.2 REST架构的特点在API中的具体应用 153
9.2 (现代)API流行背后的原因 157
9.2.1 API和云平台的普及 157
9.2.2 API与企业数字化转型、应用互联网以及API经济 158
9.3 API的平台和工具有待进一步地统一和标准化 159
9.4 一个REST API的结构 162
9.5 对 API的认识不是一蹴而就的 166
9.6 动手开发API——先尝为快 168
9.7 总结 175
第10章 围绕API的开发工作 177
10.1 API的生命周期 178
10.1.1 API的设计生命周期 178
10.1.2 API的运维生命周期 184
10.2 API的调用者 195
10.3 API项目中的人员和流程 198
10.3.1 什么是使能中心 200
10.3.2 围绕使能中心的不同角色 200
10.3.3 使能中心与绩优中心的区别 201
10.3.4 建立使能中心的具体步骤 202
10.3.5 建立使能中心的好处 208
10.4 总结 209
第11章 API与微服务 211
11.1 什么是微服务 211
11.2 微服务与服务的关系 213
11.3 微服务与API的关系 215
11.4 总结 216
第12章 API与云计算 217
12.1 云计算需求的由来 217
12.2 云计算对API技术的影响 219
12.2.1 云计算的平台能为你的API和应用提供多少服务 219
12.2.2 现有系统之间的连接是否受到影响 221
12.2.3 是否需要增加安全措施 222
12.2.4 如何将API负责对内和对外的部分分开 224
12.3 实战:全云和云-本地混合型的API平台 228
12.3.1 项目1背景 229
12.3.2 项目1云平台的架构 229
12.3.3 项目2背景 230
12.3.4 项目2混合型平台的架构 230
12.4 总结 231
第13章 最佳实践的经验 233
13.1 关于系统集成的最佳实践 235
13.1.1 不要以“数据复制”的思考方式设计系统集成 235
13.1.2 尽量避免使用批处理文件的方式 236
13.1.3 对消息服务器运行的认识 237
13.1.4 使用SEDA的架构模式来提高系统集成整体设计的可靠性 238
13.1.5 对容错、负载平衡和高可用性的考虑 240
13.1.6 对灾难恢复设置的考虑 242
13.1.7 接收JMS消息时的消息确认方式对消息处理可靠性的影响 243
13.2 关于API的最佳实践 244
13.2.1 在设计API的过程中使用“资源”的字眼,而不要使用“数据” 244
13.2.2 不要使用API的概念和方式来做系统集成 245
13.2.3 API还是连接器 246
13.2.4 API实施中的出错处理 249
13.2.5 API的URI的每一个部分都应该是名词,而不是动词 249
13.2.6 API的版本管理 251
13.3 关于架构设计的最佳实践 254
13.3.1 不要使用UML的时序图来编写系统集成的用例文件 254
13.3.2 注意区分设计中功能方面和非功能方面的要求 255
13.3.3 不要在没有系统性能指标要求的情况下对系统进行性能的评价和测试 255
13.3.4 数据验证逻辑与数据的关系 256
13.3.5 API、服务和集成中均不保留状态 256
13.4 总结 257
第14章 围绕API的展望 259
14.1 关于企业的IT欠债 260
14.2 利用API产生新的业务——创新和数字化转型 263
14.2.1 优步(Uber)的创新 264
14.2.2 邮局的数字化转型 265
14.2.3 电力公司旨在提高零售用电顾客满意度的数字化转型 265
14.2.4 玩具公司旨在减少货运差错和加快货款回收的数字化转型 266
14.3 利用API产生应用互联网和API经济 269
14.4 总结 271
第3部分 闲篇——感悟与随想 275
第15章 架构师的人文情怀 275
15.1 关于学习过程中的三个境界 275
15.2 架构师所要具备的硬实力 277
15.3 架构师所要具备的软实力 278
15.3.1 时刻分清目的和手段 279
15.3.2 处处讲究形式逻辑 280
15.3.3 强调利用抽象思维的能力 281
15.3.4 表达和交流要看对象 282
15.3.5 坚持原则,但也要知道妥协 283
15.3.6 知之为知之,不知为不知 284
15.4 架构师所处的大环境 285
15.4.1 架构师的职业规划 285
15.4.2 软件工程问题与业务问题的分离 286
15.4.3 高校计算机软件课程设置与现实对架构师要求的匹配问题 287
15.5 总结 288
附录A关于实践 289
A.1 搭建MuleSoft的开发和运行环境——开源版 290
A.1.1 开发环境 290
A.1.2 运行环境 291
A.2 安装Apache ActiveMQ消息服务器——开源版 292
附录B集成中常遇到的功能系统 295
B.1 业务流程管理系统(Business Process Management,BPM) 295
B.2 复杂事件处理(CEP) 296
B.3 云端系统 297
B.4 客户关系管理系统(CRM) 297
B.5 数据库系统(Relational、 Object 、NoSQL) 298
B.6 电子内容管理(ECM) 301
B.7 电子商务(eCommerce) 301
B.8 电子数据交换(EDI) 302
B.9 企业资源规划(ERP) 303
B.10 人力资本管理 304
B.11 行业标准 305
B.12 IT开发和运行工具 306
B.13 IT基础设施管理 306
B.14 传统系统改造 307
B.15 主数据管理 308
B.16 消息传递服务器 308
B.17 通信协议 310
B.18 社交媒体 312