1.本书开创了云原生多元环境持续部署工具Spinnaker的先例,讲解深入。
2.本书案例基于大厂一线工程师的实际工作,具有非常好的指导性和实践性。
3.本书提供丰富的图片资源和实践源码,帮助读者快速上手。
本书聚焦于云原生和多云环境的持续部署方案,共分13 章,内容涉及声明式持续部署概述、Spinnaker基础与实战、金丝雀发布与灰度发布、部署安全、混沌工程及生产化建议等,结构清晰,循序渐进,深入浅出。在持续部署最佳实践方面,本书重点介绍了如何实施灰度发布、自动金丝雀分析和混沌工程,这些高级部署功能是Netflix 公司实现快速而稳定迭代的核心技术。关于如何落地Spinnaker,本书站在人和组织架构的视角,为迁移团队提供了指导性的意见,解决了新技术落地难的问题。
目 录
01 声明式持续部署概述 1
1.1 持续交付与持续部署 2
1.2 命令式与声明式 6
1.3 常见的声明式系统 9
1.4 声明式与命令式结合:声明式脚本流水线 13
1.5 声明式脚本流水线的意义 16
1.6 本章小结 18
02 管理云基础设施 19
2.1 迁移至云原生与混合云的挑战 20
2.2 组织云基础设施 23
2.3 流量组织形式 27
2.4 持续部署工具对比 27
2.5 本章小结 36
03 Spinnaker 简介 37
3.1 概念 38
3.2 应用管理 38
3.3 应用程序部署 42
3.4 云提供商 45
3.5 Spinnaker 架构 46
3.6 本章小结 57
04 安装Spinnaker 59
4.1 环境要求 59
4.2 安装部署 67
4.3 本章小结 82
05 Spinnaker基本工作流程:流水线 84
5.1 管理流水线 85
5.2 部署制品 95
5.3 启动参数 108
5.4 阶段 109
5.5 触发器 114
5.6 通知 116
5.7 流水线表达式 118
5.8 版本控制和审计 125
5.9 动态流水线示例 126
5.10 本章小结 132
06 深入核心概念 133
6.1 虚拟机阶段 133
6.2 Kubernetes阶段 145
6.3 集成外部系统阶段 156
6.4 流程控制阶段 170
6.5 其他阶段 175
6.6 部署制品类型 176
6.7 配置触发器 192
6.8 使用流水线模板 205
6.9 消息通知 213
6.10 本章小结 226
07 自动金丝雀分析 227
7.1 Spinnaker 自动金丝雀发布 227
7.2 安装组件 229
7.3 配置金丝雀 233
7.4 获取金丝雀报告 248
7.5 工作原理 250
7.6 最佳实践 251
7.7 本章小结 253
08 混沌工程 254
8.1 理论基础 254
8.2 为什么需要混沌工程 256
8.3 五大原则 257
8.4 如何实现混沌工程 259
8.5 在 Spinnaker 中实施混沌工程 263
8.6 本章小结 268
09 使部署更加安全 269
9.1 集群部署 269
9.2 流水线执行 285
9.3 自动验证阶段 295
9.4 审计和可追溯 299
9.5 本章小结 302
10 最佳实践 303
10.1 南北流量自动灰度发布:Kubernetes + Nginx Ingress 304
10.2 东西流量自动灰度发布:Kubernetes + Service Mesh 319
10.3 本章小结 334
11 生产建议 336
11.1 SSL 336
11.2 认证 341
11.3 授权 351
11.4 Redis配置优化 359
11.5 横向扩容 360
11.6 使用MySQL 作为存储系统 363
11.7 监控 372
11.8 本章小结 382
12 扩展 Spinnaker 383
12.1 配置开发环境 383
12.2 编写新阶段 386
12.3 本章小结 394
13 迁移到Spinnaker 395
13.1 如何说服团队 395
13.2 迁移原则 396
13.3 本章小结 399
温馨提示:请使用泸西县图书馆的读者帐号和密码进行登录
持续部署这个概念被讲得很多,但真正能将其落地实践的很少。一是因为组织文化和意识不匹配,二是因为缺乏相应的工具。在云计算时代,底层基础设施不断标准化,推动了部署的标准化,Spinnaker正是在这样的背景下诞生的持续部署工具。本书不但讲解了Spinnaker的使用,还介绍了在云计算时代开发和运维人员都应该掌握的基本概念和技术。这些内容将为你打开云原生时代的大门!
——张海龙,腾讯云CODING DevOps CEO
本书系统介绍了Spinnaker的使用、安全、生产实践、扩展等多个维度的内容,将这个云原生持续部署项目全面展示给各位读者。在提倡轻量化交付的今天,熟练掌握Spinnaker对提高研发效率和交付能力至关重要。想要入门和深入学习Spinnaker的读者,都可以阅读本书。
——吴晟,Apache SkyWalking创始人
云原生本质上是一套“利用云计算技术为用户降本增效”的方法论。其中,研发与交付效能的提升是重中之重,也是持续交付技术的初衷与愿景。本书以Spinnaker为核心,从DevOps的理念出发,循序渐进地讲解了Spinnaker的来龙去脉和各项持续交付实践,是非常优秀的入门Spinnaker的学习资料。
——张磊,CNCF技术委员会成员