
配置管理过程及工具的使用.ppt
72页配置管理过程及配置管理过程及 工具的使用工具的使用 CNIC R&D 质量组议程n配置管理概念n配置项标识n配置库目录结构n配置管理过程n配置管理工具的使用配置管理概念nISO 9000-3 :1997 配置管理是一个管理学科,它对配置项(包括软件项)的开发和支持生存期给与技术上的和管理上的指导配置管理的应用取决于项目的规模、复杂程度和风险大小nW.Babich 的解释 软件配置管理能协调软件开发,使混乱减少到最小软件配置管理是一种标识、组织和控制修改的技术,目的是最有效的提高生产率nGB/T 11457 :1995《软件工程术语》国家标准 A.表示和确定系统中配置项的过程,在系统整个生存期内控制这些配置项的投放和更动,记录并报告配置的状态和更动要求,验证配置项的完整性和正确性 B.对下列工作进行技术和行动指导与监督的一套规范: —对配置项的功能特性和物理特性进行标识和文件编制工作; —控制这些特性的更动情况; —记录并报告这些更动进行的处理和实现的状态为什么需要配置管理忽视软件配置管理可能导致的混乱现象:¨标识混乱¨版本混乱¨不能协同工作¨已经解决的缺陷过后又出现错误¨找不到最新修改了的源程序¨找不到编程序的人SCMSCM的主要职责(的主要职责(1 1))变更控制变更控制配置项标识配置项标识配置状态报告配置状态报告工作产品的完整性、工作产品的完整性、一致性、可追踪性一致性、可追踪性配置审计配置审计SCM的主要职责(2)n配置项 受配置管理控制和管理的基本单位。
配置管理工作都是围绕配置项来进行n配置标识 要进行配置标识,首先必须明确项目生命周期内所要产生的工作产品,然后确定工作产品的命名和标识规则总体原则是方便在配置管理工具中进行检索和让项目组成员容易记住标识规则,同时确保在组织一级的标识规则一致性n变更管理 变更管理是项目管理的一个重点和难点,涉及的范围很广实施高效的变更管理至少应该包括二个部分,一是定义合理变更管理流程,一是采用自动化工具来支持在具体的实践中,应该对变更进行分类和分层,建立处理不同变更的变更控制委员会(CCB)构成策略,既能保证项目组成员有一定的自主权又不耽误高层经理对关键问题的把握SCM的主要职责(3)n报告配置状态报告配置状态的目的是向项目所有成员提供基线内容和状态、基线变更信息,也是实现资源共享的前提此外,在项目生命周期中通过对配置项的变更数据统计分析,有利于评估项目风险,有效控制项目的执行报告的方式可以多种多样,如Email,但应该把握好时机:变更请求被批准时;基线版本发生变化时;项目组任何需要的时候n配置审核配置审核包括两方面的内容:配置管理活动审核及基线审核配置管理活动审核确保项目组成员所有配置管理活动遵循批准的软件配置管理方针和规程,比如检入(Check in)/检出(Check Out)的频度,工作产品成熟度提升原则等。
实施基线审核,保证基线化软件工作产品的完整性和一致性,并且满足其功能要求确定配置项1、 系统规格说明2、 软件项目计划3、 软件需求规格说明书a.图形分析模型b.处理规格说明c.原型d.数学规格说明4. 初步用户手册5. 设计规格说明书a.数据设计描述b.体系结构设计描述c.模块设计描述d.接口设计描述e.对象描述(采用面向对象技术时)6. 源代码清单7、 测试规格说明 a.测试计划和步骤 b.测试用例和记录的结果8、操作和安装手册9、 可执行程序 a.模块可执行代码 b.连接的模块10、数据库描述 a.模式和文件结构 b.初始内容11、联机用户手册12、维护文档 a.软件问题报告 b.维护请求 c.工程变更指令13.软件工程标准和规程配置项标识n配置标识是软件生命周期中划分选择各类配置项、定义配置项的种类、为它们分配标识符的过程配置项标识的重要内容就是对配置项进行标识和命名n原则¨唯一性¨可追溯性¨与同类配置项不同的信息,应纳入标识:这是为了便于区分、查找¨同类配置项的标识方法统一¨容易记忆文档标识方法(1)n配置项的相关标识信息¨组名¨项目名¨文档内容¨版本号¨文档撰写时间¨文档撰写作者文档标识方法(2)n标识项目信息命名方式:[项目编号+文档名称]例如:RDMIS_需求规格说明书适用于:需求规格说明书、概要设计说明书、详细设计说明书、测试计划等等n标识版本变化版本变化不通过文档命名来标识,对于基线文档,在CVS中是通过Tag来标识。
并且,在文档的头信息中必须注明文档的版本号命名方式:[文档名称]例如:RDMIS_概要设计说明书适用于有版本变化的文档文档标识方法(3)n标识文档撰写时间命名方式:[文档名称+撰写时间]例如:RDMIS项目会议记录_20040708适用于:会议记录、项目周报、工作周报等等n标识文档作者命名方式:[文档名称+人员名称]例如:项目周报_李平_20041227适用于:项目周报、工作周报、年终工作总结等等n标识子系统或者模块名称命名方式:[项目编号+子系统名称+文档名称]例如:RDMIS_绩效考评_详细设计说明书适用于:子系统详细设计说明书、系统模块设计说明书等等文档标识方法(4)n文档首页可以包括这些信息:项目名、文档名、文档作者、本文档的版本更新历史、版本号、日期等源程序标识信息n每个源程序的首部应包括的信息为:功能描述、创建日期、作者、版本号版本号n形式:主版本号主版本号. .从版本号从版本号. .维护版本号维护版本号 n主版本号对系统作重大调整,在功能和性能上有大的变化时主版本号增加第一次版本号和第二次版本号为零版本号升级由项目组长/室主任决定n从版本号与上一版本相比,对系统功能或性能进行了少量的增加或修改,从版本号增加,主版本号不变。
版本号升级由项目组长决定n维护版本号与上一版本相比,修改了小量系统bug,维护版本号增加,主版本号和从版本号不变版本号升级由项目组长决定n通常来说,通过软件系统测试后系统版本号变为V1.0,软件系统第一次发布时版本号为V1.0.0,从版本号和维护版本号均为0CVS辅助标识方法版本的演变三个配置库 (1)开发库: 存放开发过程中需要保留的各种信息,供项目组成员使用2)基线库: 在软件开发的某个阶段工作结束时,将工作产品存入或将有关的信息存入对库内工作产品的读写和修改应该加以控制3)产品库: 在开发的软件产品完成系统测试之后,作为最终产品存入库内,等待交付用户或现场安装对库内工作产品也应该加以控制配置库目录结构配置库结构说明(1)n一级目录介绍¨基线库经过评审,变更严格控制的工作产品基线库由配置管理员建立并维护,其它任何人没有写权限¨产品库产品库由配置管理员建立并维护,整个项目结束后,配置管理员从基线库里把所有的文档挪到产品库中,其它任何人没有写权限¨开发库开发库由配置管理员创建主要目录,项目组成员可以在目录下创建子目录以及文件文件/目录的创建者本人拥有该目录/文件的完全控制权限,而项目其它成员缺省情况下是只读权限。
如果其它成员需要修改文件/目录,必须先由文件的创建者赋予权限 配置库结构说明(2)n重点目录说明—开发库目录¨计划项目计划相关文件(估计、进度)纳入基线前的文件,以及项目初始计划等¨需求纳入基线前的需求说明书等文件,需求跟踪矩阵¨设计纳入基线前的设计文件,包括概要设计、详细设计项目组长有读写权限¨源代码项目开发过程中的代码¨测试项目单元测试和集成测试所需要的工作产品和测试过程中产生的文件¨用户文档系统的安装、维护、使用手册等¨发布项目发布的工作产品包括中间发布和最后的发布配置库结构说明(3)n重点目录说明—管理目录¨配置管理放置项目配置项清单、配置管理光盘清单、配置状态报告等,SCM读写,其他人只读¨质量保证放置项目不符合报告、SQA核查表和SQA周报等,SQA读写,其他人只读¨项目跟踪和监控放置项目状态报告、项目周报、个人工作周报等¨评审和报告基线工作产品入基线时评审的报告,项目组长读写,其他人只读配置库使用说明(1)n放入正确的位置,正确标识¨因为CVS工具本身的问题,如果你将文件放在错误的位置,或者命名不规范,SCM进行位置移动或者修改文件名称的时候,会造成历史版本的丢失,想要找回历史版本很不容易,给配置管理造成一定的工作量。
¨所以请大家在进行文件入库时,注意放入正确的位置,并且正确命名,以免造成历史版本丢失n及时提交、更新¨如果习惯将自己的工作产品放在个人目录下,请及时提交或者更新到服务器上,让相关人员能够看到最新的文件¨养成良好的工作习惯,每次要对某个文件进行修改时,请首先UPDATE这个文件,从服务器上更新最新版本,以免在旧版本基础上修改,造成冲突,无法提交配置库使用说明(2)n提交规范¨文件提交到服务器上时,有“Enter the log message”,请大家一定要填写,主要填写几个方面的内容:修改的目的,修改的主要内容(段落或者函数名称),修改可能造成的影响¨尤其是进入编码和测试阶段,要求每个文件的提交必须有log message请大家注意!提交规范配置库使用说明(3)n版本发布¨每一次版本发布(包括中间的发布、最后的正式发布),把待发布工作产品(文档、源代码、安装包等)提交到“发布” 目录下,下一级目录以版本号命名;¨在发布记录中记录详细情况;¨通过电子邮件给测试人员及其他相关人员,发送软件发布通知单;¨测试人员从CVS中提取相应的版本n使用规范¨不要把CVS作为练习的场所配置管理过程n岗位及职责 n项目建立 n配置管理计划n出入库n变更流程n配置状态报告 nSCM总结报告 n验证岗位与职责nSCCB(Software Configuration Control Board)nSCCB负责人:一般由室主任、项目所有者(Project Owner)或项目负责人担当,主要职责是审批《配置管理计划》、审批重大的变更;nSCCB成员:一般由室主任、项目负责人、SQA人员共同组成,主要职责是讨论、审批配置项或基线的变更;nSQA:主要职责为审核配置管理活动;n配置管理员:主要职责为制定《配置管理计划》、创建和维护配置库、定期做《配置状态报告》。
项目建立 n首先由项目负责人提出立项申请,并按照上述岗位及职责组织合适人选共同成立软件配置控制委员会(SCCB),指定配置管理员n立项后项目负责人提交《CVS服务申请》,配置管理员按照《项目配置库定义表》的目录结构和权限设定,在CVS上创建配置库,并将项目基本信息入库 配置管理计划 n配置管理员根据项目负责人提交的项目开发计划,编写配置管理计划n配置管理计划的目标是规划整个项目的配置管理活动,尤其是重要的比如发布、基线管理等问题配置管理计划的主要内容包括人员及职责、用于配置管理的软硬件资源、配置管理环境、配置项计划、基线计划和配置库备份计划等配置管理计划直接决定了项目配置管理的方针,以及配置管理活动的准则n配置管理计划的编写可参考《配置管理计划编写指南》、《配置管理计划模板》n配置管理计划经SCCB讨论,SCCB负责人审批后,方可入库并实施入库的路径为“开发库/项目管理/配置管理” 出入库 n在进行出入库操作时,要注意以下问题:n配置库中的内容不但要具有完整性和一致性,而且还要有助于协同开发具体而言,开发库中的源代码应该以目录形式存在,而不是以压缩包的形式存在,这样开发人员不必每修改一个源代码文件就要更新整个代码包。
n开发库中除源码外,还应包括相应开发工具的配置文件,如JBuilder的项目文件(.jpx),从开发库中下载源代码后,能快速重建开发环境,直接生成可运行的系统n测试人员从配置库中获得源码,对Build之后生成的可运行系统进行测试不应该直接对开发人员提供的可运行系统进行测试n部署人员从产品库中获取要部署的软件,进行部署通常,开发人员不对运行环境进行操作变更流程n当基线库配置项需要变更时,一定要实施变更流程:变更实施前必须填写配置项变更申请,经变更评审组评审通过后,才能从基线库中提出需变更的配置项并实施变更变更实施完成后,必须通过评审才能重新进入基线库n变更流程的每一步,都需要在《配置项变更控制报告》中进行记录和落实,该文档的入库的路径为“开发库/项目管理/配置管理”入库后要以邮件方式通知SCCB成员、项目组成员、测试人员重大变更和一般变更n重大变更:配置项变更申请由项目组负责人填写,交变更评审组审核变更评审组收到变更申请后,分析此变更的必要性和技术可行性,并权衡其他的变更策略和方法,所涉及的有关配置项,对系统的功能和性能的影响,变更所需的资源是否合理、充分以及对整个工程进展和经费的影响等。
由此决策是否实施此项变更,并给出变更评审结论,同时由SCCB签署该变更申请配置管理员根据签署的变更申请,从基线库中提出需变更的配置项并实施变更变更实施完成后,必须通过SCCB评审才能重新进入基线库n一般变更:与重大变更的流程一致,区别在于配置项变更申请的审核和变更实施后的评审都由项目组负责人来做,并不由SCCB来审核,但是要以邮件的方式通知到SCCB由于不经过SCCB审核,项目组负责人在进行一般变更时一定要谨慎,对于有足够把握的非重大变更才可按此方式操作配置状态报告 n配置管理员需要定期做配置状态报告配置状态报告是配置管理的一个组成部分,其任务是有效地记录和报告管理配置所需要的信息目的是及时、准确地给出软件配置的当前状况,供相关人员了解,以加强配置管理工作n配置状态报告的编写可参考《配置状态报告编写指南》、《配置状态报告模板》n配置状态报告的入库的路径为“开发库/项目管理/配置管理”入库后要以邮件方式通知SCCB成员、项目组成员、测试人员SCMSCM总结报告总结报告n项目结束后,配置管理员需要做SCM总结报告主要包含三部分内容:配置项清单、软件发布记录、SCM活动及度量其中软件发布记录是以版本号、发布说明、发布介质、发布日期为主要内容的二维表。
SCM活动及度量是对配置状态报告的次数、软件发布的次数、配置库建立与维护工作量、配置项标识工作量、配置库用户权限管理工作量等内容进行的统计度量n配置状态报告的入库的路径为“开发库/项目管理/配置管理”入库后要以邮件方式通知SCCB成员、项目组成员、测试人员 验证 nSCCB评审配置管理员提交的《配置管理计划》,并由SCCB负责人审批n变更评审组评审配置项变更申请,并由SCCB负责人审批变更实施后,也需要变更评审组进行确认,并由SCCB负责人审批SQA验证变更是否已经通知到相关人员nSQA审核配置管理员提交的《配置管理计划》、《配置状态报告》、《SCM总结报告》是否已入库,检查配置清单的内容和配置库中的配置项是否一致nSQA审核规定流程中产生的各个文档,如《项目配置库定义表》、《配置项变更控制报告》等是否已入库 配置管理工具的使用nWincvsnJBuildernEclipsewincvs的使用点击系统_配置wincvs的使用点击系统_登陆导入模块导出模块导出模块导出模块更新文件或者模块更新文件或者模块更新文件或者模块与当前版本合并提交修改增加文件1.对于目录不存在,先增加目录。
点击“修改”-“添加选择的文件”,将目录加入2.目录存在,选中要添加的文件三种方式:添加,二进制添加,unicode添加此时文件还没真正入库3.提交修改4.对于新增的目录(目录下的子目录也是新增的),由于模块的相对性,采用导入模块的方法更快捷创建或删除标记创建分支文件版本历史n右键选择版本历史wincvs的使用n文件删除 选择文件,单击“修改”下的“删除选择的文件”,将本地的文件删除,并标记为删除状态然后选择“修改”下的“移除”,将服务器上的文件删除本地显示删除状态单击添加会恢复回来 Eclipse CVS的使用1nCheckoutEclipse CVS的使用2Eclipse CVS的使用3nCommitnUpdatenBranchnMergen……Eclipse CVS的使用4nCheckinEclipse CVS的使用5在Jbuilder中使用cvs导入新建项目谢谢大家! 什么是基线(Baseline)n定义:在配置管理系统中,基线就是一个CI或一组CIs在其生命周期的不同时间点上通过正式评审而进入正式受控的一种状态,而这个过程被称为“基线化”。
基线是被评审过的一个或多个软件配置项n每一个基线都是其下一步开发的出发点和参考点基线确定了元素(配置项)的一个版本,且只确定一个版本一般情况下,基线一般在指定的里程碑处创建,并与项目中的里程碑保持同步Return。
