新書推薦:
《
盛世滋生:清代皇权与地方治理
》
售價:HK$
162.8
《
循序渐进Node.js企业级开发实践
》
售價:HK$
97.9
《
海外中国研究·中国早期的星象学和天文学
》
售價:HK$
152.9
《
诡计策划师 午夜文库
》
售價:HK$
53.9
《
管道的力量(畅销美国30年的财富经典,销量超100万册)
》
售價:HK$
54.8
《
长安曾有少年郎
》
售價:HK$
43.8
《
何以为园:中国江南古典私家园林的经济解释
》
售價:HK$
74.8
《
漫画图解博弈论:段位经商谋略之道 赢家是怎样炼成的
》
售價:HK$
43.8
|
內容簡介: |
软件交付过程是指在编程序改代码之后,直到将软件发布给用户使用之前的一系列活动,如提交、集成、构建、部署、测试等。本书作为通识类图书,对软件交付过程的各个方面进行了全面综合的介绍。这包括三部分内容:第1部分,介绍在研究软件交付过程时常见的思路和思考框架;第2部分,梳理软件交付的总体过程;第3部分,考查软件交付过程中的各个具体活动。总的来说,本书提供了一种类似于对人进行体检的方法,对特定软件产品的交付过程进行全方位的调研,可以根据其所在的业务领域、当前采用的技术栈、使用的工具、流程和方法等实际情况,找出当前突出、值得改进的问题。
|
關於作者: |
董越,DevOps 资深专家,阿里巴巴集团前研发效能事业部架构、高级产品专家等职,从事 Aone&云效 DevOps 产品设计、阿里云专有云集成与交付解决方案设计等工作。在加入阿里之前,他还曾就职于西门子、摩托罗拉、雅虎、索尼、去哪儿网等大型企业,一直从事软件配置管理、软件集成与交付、DevOps 相关的工作。当前主要从事企业级DevOps体系建设与咨询工作,帮助众多企业提升软件研发交付效能。已服务过的客户有华为、工商银行、交通银行、招商银行、中信银行、中国移动、中国联通、中国电信、华泰证券、泰康人寿等。
|
目錄:
|
第1部分 思维方式
第1章 本书要解决什么问题2
1.1 提供一种系统全面的方法2
1.2 分析软件交付过程3
1.3 软件交付过程包括三类事情4
1.4 软件交付不是按时间阶段或角色划分出来的4
1.5 本书本质上是讲述软件交付这门学科5
1.6 本书分成三个部分讲述5
第2章 我们要追求什么6
2.1 一切为了业务的成功6
2.2 小步快跑7
2.3 软件实现侧该追求什么目标8
2.4 软件交付过程追求的目标10
第3章 几十年来的探索12
3.1 软件工程12
3.1.1 软件危机12
3.1.2 工程化13
3.2 敏捷14
3.2.1 敏捷的理念14
3.2.2 敏捷的实践15
3.3 精益16
3.3.1 起源于制造业的精益思想16
3.3.2 把精益应用于软件开发17
3.4 持续集成18
3.4.1 持续集成是什么18
3.4.2 为什么要持续集成19
3.4.3 如何做到持续集成19
3.5 持续交付20
3.5.1 包括所有质量验证工作20
3.5.2 比较频繁地发布上线21
3.5.3 持续部署22
3.6 DevOps22
3.6.1 DevOps的诞生22
3.6.2 DevOps三步工作法23
3.6.3 DevOps落地实践23
3.7 技术方面的演进24
3.7.1 软件架构24
3.7.2 部署运行24
3.8 它们之间是什么关系25
第4章 做好软件交付的10个策略27
4.1 细粒度、低耦合、可复用的架构27
4.1.1 软件架构27
4.1.2 测试脚本和测试数据的架构28
4.1.3 组织架构29
4.2 小批量持续流动的流程30
4.2.1 大批量带来等待等问题31
4.2.2 短周期、小颗粒度、减少在制品31
4.2.3 小批量持续流动的交付过程32
4.3 运用综合手段保证质量和安全32
4.3.1 各种各样的测试32
4.3.2 左移 右移33
4.3.3 测试人员 开发人员33
4.3.4 人工测试 自动化测试33
4.3.5 综合运用34
4.4 自动化与自助化34
4.4.1 单项活动的自动化34
4.4.2 流程的自动化34
4.4.3 自助化35
4.4.4 相关支持35
4.5 加速各项活动35
4.5.1 为什么要加速35
4.5.2 加速的通用思路36
4.6 及时修复36
4.6.1 为什么要及时修复37
4.6.2 如何做到及时修复37
4.7 完备记录,充分展现38
4.7.1 任务及其执行情况38
4.7.2 版本和配置信息39
4.7.3 关联关系40
4.7.4 单一可信源40
4.7.5 相关支持41
4.8 标准化41
4.8.1 规范可重复41
4.8.2 方案收敛41
4.8.3 环境一致性42
4.9 协调完成完整功能43
4.9.1 背景43
4.9.2 开发全过程的协调43
4.9.3 交付过程的协调43
4.10 基于度量的持续改进44
第5章 一个典型的软件交付过程47
5.1 前传47
5.2 代码改动累积并终提交48
5.3 特性改动累积并终提交48
5.4 集成并终发布49
第6章 各个细分领域51
6.1 交付过程51
6.2 源代码及其构建52
6.3 部署运行54
6.4 静态测试54
6.5 动态测试55
第7章 各个关注角度58
7.1 执行时机58
7.2 执行效果60
7.3 执行效率61
7.4 问题处理效率62
7.5 避免引入问题64
第2部分 总体过程
第8章 代码改动累积68
8.1 导论68
8.1.1 考查范围68
8.1.2 关注重点68
8.2 执行时机68
8.2.1 包含改动的颗粒度:实时进行的测试68
8.2.2 包含改动的颗粒度:随时进行的测试69
8.3 执行效率70
第9章 代码改动提交71
9.1 导论71
9.1.1 考查范围71
9.1.2 关注重点71
9.2 执行时机72
9.2.1 包含改动的颗粒度:提交的颗粒度72
9.2.2 包含改动的颗粒度:提交时进行的测试72
9.3 执行效果73
9.4 执行效率73
9.4.1 执行效率度量:从发起提交到提交完成的时间73
9.4.2 工具辅助记录和展现:代码改动提交说明73
9.4.3 工具间集成:代码改动提交与工作项关联74
第10章 特性改动累积75
10.1 导论75
10.1.1 特性的概念75
10.1.2 特性隔离76
10.1.3 考查范围76
10.1.4 关注重点76
10.2 执行时机76
10.2.1 包含改动的颗粒度:代码改动提交触发的测试76
10.2.2 包含改动的颗粒度:随时进行的测试77
10.2.3 流程顺序和卡点:适当并行78
10.2.4 管理并发:控制在研的特性数量78
10.2.5 整体协调:完整的特性79
10.3 执行效果79
10.4 执行效率81
10.4.1 自动执行:构建流水线81
10.4.2 工具辅助记录和展现:流水线执行情况81
10.4.3 方案收敛82
10.5 问题处理效率83
10.5.1 问题处理效率度量83
10.5.2 适当通知83
10.5.3 记录版本:流水线配置的修改历史83
10.6 避免引入问题84
第11章 特性改动提交86
11.1 导论86
11.1.1 考查范围86
11.1.2 关注重点86
11.2 执行时机86
11.2.1 包含改动的颗粒度:特性的颗粒度86
11.2.2 包含改动的颗粒度:当特性做不到既小又独立时87
11.2.3 包含改动的颗粒度:特性提交时进行的测试88
11.2.4 流程顺序和卡点:特性提交门禁89
11.2.5 整体协调:完整的特性89
11.3 执行效果90
11.4 执行效率90
11.4.1 执行效率度量:从发起提交到提交完成的时间90
11.4.2 自动执行:合并请求91
11.4.3 工具辅助记录和展现:特性内容说明91
11.4.4 工具间集成:特性的代码改动与工作项之间的关联92
11.5 问题处理效率92
11.5.1 问题处理效率度量92
11.5.2 适当通知93
11.5.3 便捷回退:特性摘除93
第12章 集成94
12.1 导论94
12.1.1 考查范围94
12.1.2 关注重点94
12.2 执行时机94
12.2.1 包含改动的颗粒度:持续接收特性改动提交94
12.2.2 包含改动的颗粒度:特性合入触发的测试95
12.2.3 包含改动的颗粒度:针对新特性的测试95
12.2.4 流程顺序和卡点:制品晋级96
12.2.5 管理并发:适当交叠97
12.2.6 管理并发:管理变体98
12.3 执行效率99
12.3.1 自动执行:部署流水线99
12.3.2 工具间集成:版本的特性列表100
12.3.3 工具间集成:特性状态信息101
12.3.4 工具间集成:自动维护说明文档102
12.3.5 自主完成:各项活动102
12.3.6 自主完成:工具的配置103
12.3.7 便捷配置103
12.4 问题处理效率103
12.4.1 问题处理效率度量:红灯修复时长103
12.4.2 问题处理效率度量:缺陷修复时长104
12.4.3 及时发现104
12.4.4 适当通知105
12.4.5 及时处理105
12.4.6 快速定位106
12.5 避免引入问题106
第13章 发布107
13.1 导论107
13.1.1 考查范围107
13.1.2 关注重点107
13.2 执行时机108
13.2.1 包含改动的颗粒度:发布的颗粒度108
13.2.2 包含改动的颗粒度:发布前的测试109
13.2.3 包含改动的颗粒度:生产环境的测试109
13.2.4 减少等待:发布时间窗口109
13.2.5 操作对象的颗粒度110
13.2.6 整体协调:按一定顺序发布111
13.2.7 整体协调:当在特性分支上完成全部测试时112
13.2.8 整体协调:当每个微服务都有自己的迭代节奏时113
13.2.9 整体协调:静态库典型情况之公共基础库114
13.2.10 整体协调:静态库典型情况之整体应用的组成部分115
13.2.11 整体协调:静态库典型情况之服务接口定义116
13.3 执行效果117
13.4 执行效率117
13.4.1 执行效率度量117
13.4.2 自主完成:精简发布审批流程118
13.5 问题处理效率118
13.5.1 问题处理效率度量:故障恢复与缺陷修复的时长118
13.5.2 及时发现118
13.5.3 适当通知119
13.5.4 及时处理119
13.5.5 快速定位119
13.5.6 便捷回退:发布回滚119
13.5.7 紧急改动的生效方式:紧急发布120
第3部分 具体活动
第14章 源代码版本控制122
14.1 导论122
14.1.1 考查范围122
14.1.2 关注重点122
14.2 执行时机123
14.2.1 管理并发:晚分叉模式支持交叠123
14.2.2 管理并发:早分叉模式支持交叠124
14.2.3 管理并发:用主干代表已发布版本125
14.2.4 管理并发:特性分支的管理126
14.2.5 操作对象的颗粒度:代码库的尺寸127
14.3 执行效果127
14.4 执行效率128
14.4.1 执行效率度量128
14.4.2 快速执行:分布式版本控制工具128
14.4.3 快速执行:便捷的页面操作129
14.4.4 规范可重复:管理众多代码库129
14.4.5 规范可重复:明确代码库内的目录结构和内容129
14.4.6 规范可重复:规范版本号130
14.4.7 规范可重复:标识源代码版本131
14.5 问题处理效率132
14.5.1 便捷回退:特性摘除132
14.5.2 便捷回退:发布回滚132
14.5.3 紧急改动的生效方式:已提交特性的修改133
14.5.4 紧急改动的生效方式:紧急发布133
14.6 避免引入问题134
第15章 构建135
15.1 导论135
15.1.1 构建的概念135
15.1.2 考查范围136
15.1.3 关注重点136
15.2 执行时机136
15.3 执行效率137
15.3.1 工具辅助记录和展现:构建遇到的问题137
15.3.2 快速执行:从全局视角提速构建138
15.3.3 规范可重复:构建的可重复性140
第16章 构建环境管理142
16.1
|
|