Software Configuration Management 即软件配置管理,也就是软件版本管理控制。简称 SCM
为什么会有SCM?
在比较大的项目中,一般需要的开发人员比较多,所以凸显的问题就太多了,比如:
在许多人共同开发一个项目下,一个程序员如何得到最新版本?
对于版本的修改情况,代码哪些更新过了?
如何查询或者更新到之前的版本(当前版本出问题的情况下)。
项目经理准确的得到当前的工作进度。
开发人员都改变相同版本的代码,做了同样的工作或者代码发生冲突。
记录开发历史,不方便比较不同和修改。
..........................
SCM就是能够解决这些问题而诞生。
SCM历史?
起始于1970年,先用于 UNIX下开发的版本管理控制。
发展历程:
起始于:
SCCS (Source Code Control System)
RCS (Revision Control System)
演变:
SCCS→Codemgr→TeamWare
RCS→CVS
SVN --------SVN是异军突起,它满足CVS的功能,并且解决了CVS一些致命的缺点。所以现在大部分都在使用SVN了。
SCM主要作用?
Version Control(版本控制和产品数据管理)
其他----(从程序员的角度来说很少用哦)
SCM的主要术语?
(了解概念)
Repository ---代码仓库
Workspace ---工作台 (就是客户端的上传下载代码的目录)
Delta () ---不同版本的差别的保存。(文件和项目都有不同的版本,不同的版本比较不同的变化来做保存)--了解概念
Baseline ---基线(HEAD)
Branch ---分支(拷贝出两个项目,发展不同的功能或者做bug修改)
Label ---标签(Tag)
国际性的一些大公司,他们开发自己的版本控制和代码管理工具,而且更自动化,可以自己更新,实现测试代码,发现bug等强大的功能,但是一般都是不开源的私人工具。例如:微软的操作系统团队版本控制工具。
SCM哪些人在用?
Project manager -----(项目经理)
Software engineer -----(开发者)
QA manager -----(测试经理)
QA engineer -----(测试人员)
Build and release engineer ------(构建经理)
SCM目前使用最多的工具?
CVS
SVN
VSS(微软)
ClearCase
TeamWare
---------------分割线-----------------------
写本文是想彻底去了解为什么会产生版本控制工具,他的历史,以及明白现在用的SVN是如何发展到现在这一步的。
文章做了概念性的说明,没有去项目分析每一句。只希望快速的去明白一些概念。(有 概念综合征的人 请绕道,或者请看下篇实际操作)
下篇对SVN在windows下的操作和SVN在Eclipse里面做的操作做一个总结(从程序员角度)