描述
开 本: 16开纸 张: 胶版纸包 装: 平装-胶订是否套装: 否国际标准书号ISBN: 9787121328497
√ 书中介绍了很多从一线项目实践中总结出来的优秀实践
√ 作者对代码管理的方法论、工具及未来都有深刻的认知
√ 在一切“XX as Code”的风潮下,代码管理等同于高效的工程化开发
√ 本书是每一名写代码、使用代码或管理代码的人员值得拥有的经典书籍
第1章 代码版本管理工具与系统 2
1.1 引言 2
1.2 代码版本管理工具的历史 3
1.2.1 第1代:本地代码管理 3
1.2.2 第2代:中心服务器代码管理 3
1.2.3 第3代:分布式代码管理 4
1.3 常用的代码管理工具 5
1.3.1 Perforce 5
1.3.2 Subversion 6
1.3.3 Git 6
1.3.4 Mercurial 7
1.3.5 Microsoft GVFS (Git Virtual File System) 7
1.4 常用的代码管理系统 8
1.4.1 Virtual SVN Server 9
1.4.2 GitLab Server 9
1.4.3 Gerrit Server 10
1.5 从Subversion迁移到Git的常用工具和方法 11
1.5.1 SubGit 11
1.5.2 git-svn 12
1.5.3 手动 12
1.6 常用云端代码管理系统 13
1.6.1 Sourceforge和Google Code 13
1.6.2 GitHub 14
1.6.3 GitLab和Bitbucket 14
1.6.4 Coding、码云、阿里云Code 15
第2章 独立小型团队 17
2.1 启程:团队与项目 17
2.2 痛点与需求 18
2.2.1 如何选择和搭建Subversion Server 18
2.2.2 定制代码库结构 20
2.2.3 分支策略 22
2.2.4 日常工作模式 24
2.2.5 备份策略 26
2.3 阿里云Code 27
2.3.1 将内网Subversion迁移到阿里云Code 28
2.3.2 权限管理 31
2.3.3 日常工作模式 32
2.3.4 备份方案 33
2.4 小团队代码管理的经典模型 34
第3章 传统中大型团队 36
3.1 传统大型团队的特点 36
3.2 独立大型团队在代码管理上的痛点与需求 38
3.3 大型团队代码管理案例 39
3.3.1 代码模块依赖管理 41
3.3.2 建立相关运作机制 44
3.3.3 建立原子提交的纪律 46
3.3.4 建立持续集成守护机制 47
3.3.5 大型团队代码管理小结 51
3.4 大型团队的代码服务器迁移 51
第2部分 当前与流行
第4章 分布式中大型团队 58
4.1 分布式中大型团队的特点 58
4.2 分布式中大型团队在代码管理上的痛点与需求 59
4.2.1 离线代码管理 60
4.2.2 在线代码审查 61
4.2.3 对代码进行分布式权限管理 66
4.2.4 对代码进行分布式提交和集成 73
4.3 代码仓库拆分与集成 74
4.3.1 优化单代码仓库 77
4.3.2 代码仓库的拆分 87
4.3.3 代码仓库的集成 91
4.3.4 小结 122
4.4 分支策略 123
4.4.1 主干开发分支策略 124
4.4.2 应对并行开发 132
4.4.3 定制分支策略 147
4.5 代码库热备份 150
4.5.1 服务器端热备份方案 150
4.5.2 客户端热备份方案 151
4.6 案例:Android定制化系统开发 151
4.6.1 项目背景 151
4.6.2 项目及其代码管理介绍 152
4.6.3 分支策略 155
4.7 多产品线 157
4.7.1 多产品线介绍 158
4.7.2 多产品线开发的困境 158
4.7.3 多产品线解决方案 158
4.8 超大型分布式团队 166
第3部分 发展与未来
第5章 云时代微服务大型分布式团队 172
5.1 云时代和微服务架构 172
5.2 Everything as Code(一切即代码) 173
5.3 代码管理团队自治 175
5.3.1 围绕团队的代码库管理 177
5.3.2 围绕服务的代码库管理 177
5.4 微服务架构下的代码管理挑战 179
5.5 微服务代码管理实例 180
第6章 开源项目与开源社区 184
6.1 开源软件 184
6.1.1 开源软件的特点 185
6.1.2 开源软件和社区 185
6.1.3 开源软件和商业 186
6.1.4 开源软件的代码管理 186
6.2 开源社区中的开源项目 187
6.2.1 简介 187
6.2.2 代码管理模型 187
6.2.3 典型的大型分布式开源项目 189
6.3 企业中的开源项目 193
6.3.1 简介 193
6.3.2 代码管理模型 193
6.4 GitHub中的开源项目实践 195
6.4.1 分支管理 195
6.4.2 分库管理 197
6.4.3 把公开代码库转换成私有代码库 203
6.4.4 GitHub的分支与复刻 205
参考文献 207
名词解释 209
我从2004年开始直到现在都在从事软件开发工作,经历了没有代码版本管理、代码集中式管理,以及现在的分布式代码管理,在这一过程中,我深刻体会到代码管理在软件开发中的重要性。近几年,随着软件开发规模越来越大,开发团队的规模也随之扩大,出现了越来越多的分布式团队,工程效率问题也越来越突出,比如QCon在2016年首次举办了“工程效率提升”专题。由此可见工程效率已经成为现代软件业中一个无法让人忽视的问题。
在工程效率这个范畴里,代码管理占据了举足轻重的地位,因为代码是开发人员每天工作的主要对象和内容,如果不能有效地管理,必然会影响开发人员的工作效率。随着团队规模的扩大,代码管理对团队工程效率的影响也越来越大。而高效的代码管理就像一根纽带,把所有程序员有效地串联起来,让程序员可以更高效地协同开发、编写代码,完成软件的开发工作。我们在咨询工作中遇到的很多客户都对使用代码版本管理有各种问题和困惑。出于以上原因,我们觉得有必要基于经验写一本代码管理实践相关的图书。鉴于时间有限,在本书中我们只选择了自己认为核心的技术及实践。
本书首先通过系统化的介绍和比较,让读者从整体上系统地了解代码管理工具的历史和发展。然后分别从小型团队、中大型团队、分布式大团队、基于微服务的团队及开源团队的角度,总结了代码管理的核心技术及实践,其中包括不同类型的团队对代码管理工具的选择、代码管理的流程、策略和技巧,以及一些代码管理工具和系统的难点和痛点等,可帮助读者在现实中从团队规模的大小、集中式还是分布式、开源还是闭源等角度去了解和思考代码管理的实践经验。
全书共分3部分,其中第1部分主要系统化地介绍了代码管理的历史和分类,列举并简单比较了业界常用的各种代码管理工具和系统,以及迁移工具等基础知识,以帮助读者更好地选择代码管理工具。主要以集中式代码管理工具Subversion为主,并以一个虚拟小团队的工作流程介绍小团队的代码管理实践,后总结了我们经历过的传统中大型团队的代码管理的核心技术及实践。第2部分以介绍当前流行的分布式代码工具Git为主,结合大型软件项目和分布式开发团队介绍了当前流行的分布式软件开发中代码管理的核心技术及实践。第3部分主要介绍了正在兴起的微服架构下的代码管理实践,以及一种越来越重要的软件开发模式:开源模式下的各种代码管理核心技术及实践。
阅读提示:本书不是介绍代码管理工具的专业书籍,所以不会对书中提到的代码管理工具或系统进行全面性和系统性的介绍,所以读者需要对书中提到的代码管理工具或系统全面和深入地进行学习,并阅读与其对应的专业书籍,比如Subversion的Version Control with Subversion、Git的Pro Git等。如果读者来自一个大型团队,则可以略过第2章的独立小团队的内容,在剩下的章节中找到有用的知识点。如果读者来自一个小型团队,那么可以将第3、4、5章作为兴趣阅读,但是在尝试里面的一些核心技术和实践之前一定要认真思考,因为它们很可能并不适应读者现在的团队环境和规模。它们更像是一把双刃剑,所以不妨将这些内容作为未来团队扩张之前的知识储备。
书中难免存在一些错误和不妥之处,敬请谅解并欢迎指出,我们将及时修改并发表在勘误中,谢谢。
刘冉
2017年10月12号写于成都
——ThoughtWorks洞见主编 张凯峰
以我的理解,代码管理本质上是对写代码的人的一种管理形式。类比控制论,人的编码行为的可能性空间是无限的,而代码的目标范围是明确的。为了实现目标,我们需要通过工具将人的编码行为缩小到可控的范围内,我们可以从中看到工具本身和如何使用工具的重要性。感谢作者系统性地总结了代码管理工具和优秀实践,便于开发人员随时查阅和参考,值得作为团队的常备书。
——迅达云成副总裁 崔康
代码管理是软件研发管理中的基础管理过程,这一过程是否规范、高效或优雅,直接折射出一个团队乃至一个组织的管理成熟度。作者在本书中从代码管理相关的工具、技术、管理策略出发,延伸到与代码管理息息相关的代码架构、依赖管理、持续集成、微服务等技术管理实践,由浅入深、娓娓道来。本书是每一名写代码、使用代码或管理代码的人员值得拥有的经典书籍。
——工行软件开发中心持续集成平台负责人 吴利华
版本控制系统是在任何严肃的工程中都必须用到的,就像水和空气一样重要。特别是在涉及多人协同、跨地域协作等内容的场景中,版本控制系统更是对项目的开发效率和代码安全起着决定性的支持作用。
本书介绍了版本控制系统的历史渊源及对常见的版本控制系统的使用,并根据不同的团队大小介绍不同的版本控制策略。难能可贵的是,书中介绍了很多从一线项目实践中总结出来的优秀实践,比如分支策略、持续集成的配合使用、大型分布式团队的协作等。除了理论知识,书中还提供了很多实际案例,读者可以通过对这些案例的学习,将这些原则应用到自己的工程中,以便让版本控制系统更有效地帮助团队。
——ThoughtWorks资深技术专家、技术作家
《JavaScript核心概念及实践》《轻量级Web应用开发》等书作者 邱俊涛
代码管理对于银行的一支核心队伍来说是非常重要的。一个系统有几十年的历史,经历了无数版本,有上千人的开发团队及多个国家的不同版本,所有这些都是一个复杂而庞大的工程。其中,代码管理对于工具、方法论及实践检验,都起着核心和基石的作用。作者对代码管理的方法论、工具及未来都有深刻的认知。整本书由浅入深地讲述了相关的概念,给出了相应的例子,很多个案都切中要害,值得有经验的从业人员认真阅读。
——某跨国银行软件开发中心测试经理
评论
还没有评论。