CMMI之配置管理

news2025/1/23 7:13:21

配置管理(Configuration Management, CM)的目的是通过执行版本控制、变更控制等规程,以及使用配置管理软件,来保证所有配置项的完整性和可跟踪性。配置管理是对工作成果的一种有效保护。

配置管理过程域是SPP模型的重要组成部分。本规范阐述了配置管理过程域的四个主要规程:

  • 制定配置管理计划 [SPP-PROC-CM-PLANNING]

  • 配置库管理 [SPP-PROC-CM-LIB]

  • 配置项版本控制 [SPP-PROC-CM-VERSION]

  • 配置项变更控制 [SPP-PROC-CM-CHANGE]

上述每个规程的“目标”、“角色与职责”、“启动准则”、“输入”、“主要步骤”、“输出”、“完成准则”和“度量”均已定义。

本规范适用于国内IT企业的软件研发项目。建议用户根据自身情况(如商业目标、研发实力等)适当地修改本规范,然后推广使用。

1介绍

项目研发和管理过程中会产生许许多多的工作成果,例如文档、程序和数据等,它们都应当被保存起来,以便查阅和修改。如果把所有文件一股脑地塞进计算机里,那么使用起来肯定很麻烦。毫无疑问,人们应当将文件分门别类、有条理地保存起来。

凡是纳入配置管理范畴的工作成果统称为配置项(Configuration Item, CI),配置项主要有两大类:

(1)属于产品组成部分的工作成果,例如需求文档、设计文档、源代码、测试用例等。

(2)项目管理和机构支撑过程域产生的文档。这些文档虽然不是产品的组成部分,但是值得保存。

每个配置项的主要属性有:名称、标识符、文件状态、版本、作者、日期等。所有配置项都被保存在配置库里,确保不会混淆、丢失。配置项及其历史记录反映了软件的演化过程。

基线(Baseline)由一组配置项组成,这些配置项构成了一个相对稳定的逻辑实体。基线中的配置项被“冻结”了,不能再被任何人随意修改(见变更控制规程)。基线通常对应于开发过程中的里程碑(Milestone),一个产品可以有多个基线,也可以只有一个基线。基线的主要属性有:名称、标识符、版本、日期等。通常将交付给客户的基线称为一个“Release”,为内部开发用的基线则称为一个“Build”。

所有的项目成员都要使用配置管理软件来保护自己的工作成果。机构应当采用统一的配置管理软件,常见的配置管理软件有Microsoft的Visual SourceSafe和Rational的ClearCase等。为了提高配置管理的效率和安全性,机构应当有专门的配置管理员(角色)。配置管理员为每个项目制定《配置管理计划》,创建和维护配置库。

鉴于配置管理的重要性和复杂性,机构还应当设立配置控制委员会(Configuration Control Board, CCB)。CCB是个虚拟小组,对配置管理各项活动拥有决策权(例如审批计划,审批变更请求等)。对于配置管理而言,CCB是决策者,而配置管理员是执行者。

如果机构的各个项目紧密相关(例如一个产品线下的多个项目),建议机构设立公共的CCB,这个公共的CCB对所有项目的配置管理拥有决策权。如果机构的各个项目相对独立,那么每个项目可以设立各自的CCB。CCB的决策采用“少数服从多数”原则。

配置管理的流程如图所示。

一、制定配置管理计划

配置管理员制定《配置管理计划》,主要内容包括配置管理软硬件资源、配置项计划、基线计划、交付计划、备份计划等。CCB审批该计划。

二、配置库管理

配置管理员为项目创建配置库,并给每个项目成员分配权限。各项目成员根据自己的权限操作配置库。配置管理员定期维护配置库,例如清楚垃圾文件、备份配置库等。

三、版本控制

在项目开发过程中,绝大部分的配置项都要经过多次的修改才能最终确定下来。对配置项的任何修改都将产生新的版本。由于我们不能保证新版本一定比老版本“好”,所以不能抛弃老版本。版本控制的目的是按照一定的规则保存配置项的所有版本,避免发生版本丢失或混淆等现象,并且可以快速准确地查找到配置项的任何版本。

配置项的状态有三种:“草稿”、“正式发布”和“正在修改”,本规程制定了配置项状态变迁与版本号的规则。

四、变更控制

在项目开发过程中,配置项发生变更几乎是不可避免的。变更控制的目的就是为了防止配置项被随意修改而导致混乱。

修改处于“草稿”状态的配置项不算是“变更”,无需CCB的批准,修改者按照版本控制规则执行即可。

当配置项的状态成为“正式发布”,或者被“冻结”后,此时任何人都不能随意修改,必须依据“申请-审批-执行变更-再评审-结束”的规则执行。

五、配置审计

为了保证所有人员(包括项目成员、配置管理员和CCB)都遵守配置管理规范,质量保证人员要定期审计配置管理工作。配置审计是一种“过程质量检查”活动,是质量保证人员的工作职责之一。请参考质量保证规范SPP-PROC-QA,此处不再论述。

配置管理过程域产生的主要文档有:

  • 《配置管理计划》,模板见[SPP-TEMP-CM-PLAN]。

  • 《配置库管理报告》,模板见[SPP-TEMP-CM-LIB]。

  • 《配置项变更控制报告》,模板见[SPP-TEMP-CM-CHANGE]。

17.2 制定配置管理计划

17.2.1 目的

  • 制定配置管理计划,以便有计划地开展配置管理工作。

17.2.2 角色与职责

  • 配置管理员制定《配置管理计划》。

  • CCB审批《配置管理计划》。CCB的人数视项目的规模而定。通常CCB由项目经理、资深项目成员等人组成,项目经理为CCB负责人。CCB的决策采用“少数服从多数”原则。

17.2.3 启动准则

  • 《项目计划》已经制定

  • 配置管理员和CCB已经确定。

17.2.4 输入

  • 《项目计划》

17.2.5 主要步骤

[Step1] 确定配置管理的软硬件资源

  • 配置管理员根据项目的规模以及财力,确定配置管理软件以及计算机资源(考虑内存、外存、CPU等)。常用的配置管理软件有Microsoft公司的Visual SourceSafe和Rational公司的ClearCase等。

[Step2] 制定配置项计划

  • 配置管理员识别项目的主要配置项。每个配置项都有唯一的标识符,标识符的参考格式为Project-Type…Type-Number。

  • 可以在Project(或Product)前面加上公司的标识符。

  • Type…Type表示配置项类型,可以采用多级缩写。

  • Number为3为数字,范围从001到999,表示一个配置项有若干个文件。若配置项只有一个文件,则该项可以省略。

  • 配置项计划的参考格式如下:

[Step3] 制定基线计划

配置管理员确定每个基线的名称(标识符)及其主要配置项,估计每个基线建立的时间。基线计划的参考格式如下:

[Step4] 制定配置库备份计划

  • 配置管理员制定配置库备份计划,指明“何人”在“何时”(频度)将配置库备份到“何处”。

[Step5] 审批《配置管理计划》

  • CCB审批《配置管理计划》。若该计划被批准,则请CCB负责人签字认可。否则,配置管理员按照CCB的意见修改《配置管理计划》,直到该计划被批准为止。

17.2.6 输出

  • 《配置管理计划》

17.2.7 结束准则

  • 《配置管理计划》已经制定并被CCB的批准。

17.2.8 度量

  • 配置管理统计工作量以及文档的规模,汇报给项目经理。

17.3 配置库管理

17.3.1 目的

  • 所有人员依照配置管理规范和《配置管理计划》操作配置库。

17.3.2 角色与职责

  • 配置管理创建并维护配置库。

  • 项目成员在权限之内操作配置库。

17.3.3 启动准则

  • 《配置管理计划》已经制定。

  • 配置管理的软件硬件已经存在。

17.3.4 输入

  • 《配置管理计划》

17.3.5 主要步骤

[Step1] 创建配置库

  • 配置管理员创建配置库,并且至少创建配置库的所有第一级目录。

[Step2] 分配权限

  • 配置管理员为每个项目成员分配操作权限。一般地,项目成员拥有Add, Checkin/Checkout, Download等权限,但是不能拥有“删除”权限。配置管理员的权限最高。具体操作视所采用的配置管理软件而定。

[Step3] 配置库操作与管理

  • 项目成员根据自己的权限操作配置库,例如Add, Checkin/Checkout, Download等。

  • 配置管理员根据“基线计划”创建与维护基线,“冻结”配置项,控制变更。

  • 配置管理员定期清除配置库里的垃圾文件。

  • 配置管理员定期备份配置库。

  • 交付管理。这里“交付”是指从配置库中提取配置项,交付给客户或项目外的人员。交付出去的配置项必须有据可查,避免发生混乱。流程如下:

  1. “索取人”向CCB提出交付申请。

  1. CCB审批该申请。如果该申请不合法(合理),则拒绝交付配置项。如果同意交付,CCB应给出详细的交付清单。

  1. 配置管理员依据CCB的批示,从配置库中提取配置项交付给“索取人”。

  1. “索取人”验收后签字。

17.3.6 输出

  • 《配置库管理报告》(由配置管理员撰写)

17.3.7 结束准则

  • 对配置库的操作与管理将持续到项目结束。

17.3.8 度量

  • 配置管理员统计工作量以及文档规模。

17.3 版本控制

17.3.1 目的

  • 按照一定的规则保存配置项的所有版本,避免发生版本丢失或混淆等现象,并且可以快速准确地查找到配置项的任何版本。

17.3.2 角色与职责

  • 所有项目成员都必须遵照版本控制规程操作配置库。

17.3.3 配置项状态变迁规则

配置项的状态有三种:“草稿”(Draft)、“正式发布”(Released)和“正在修改”(Changing)。

配置项状态变迁如图17-2所示。配置项刚建立时其状态为“草稿”。配置项通过评审(或审批)后,其状态变为“正式发布”。此后若更改配置项,必须依照“变更控制规程”执行,其状态变为“正在修改”。当配置项修改完毕并重新通过评审(或审批)时,其状态又变为“正式发布”,如此循环。

17.3.4 配置项版本号规则

配置项的版本号与配置项的状态紧密相关:

(1)处于“草稿”状态的配置项的版本号格式为:0.YZ

  • YZ数字范围为01-99。

  • 随着草稿的不断完善,“YZ”的取值应递增。“YZ”的初值和增幅由用户自己把握。

(2)处于“正式发布”状态的配置项的版本号格式为:X.Y

  • X为主版本号,取值范围为1-9。Y为次版本号,取值范围为1-9。

  • 配置项第一次“正式发布”时,版本号为1.0。

  • 如果配置项的版本升级幅度比较小,一般只增大Y值,X值保持不变。只有当配置项版本升级幅度比较大时,才允许增大X值。

(3)处于“正在修改”状态的配置项的版本号格式为:X.YZ

  • 配置项正在修改时,一般只增大Z值,X.Y值保持不变。

  • 当配置项修改完毕,状态重新成为“正式发布”时,将Z值设置为0,增加X.Y值。参见规则(2)。

17.3.4 配置项版本控制流程

[Step1] 创建配置项

  • 项目成员依据《配置管理计划》,在配置库中创建属于其任务范围内的配置项。此时配置项的状态为“草稿”,其版本号格式为0.YZ。

[Step2] 修改处于“草稿”状态的配置项

  • 项目成员使用配置管理软件的Checkout/Checkin功能,可以自由修改处于“草稿”状态的配置项(不受变更控制规程约束),版本号格式为0.YZ。

[Step3] 技术评审或领导审批

  • 如果配置项是技术文档,则需要接受技术评审(参见技术评审规程[SPP-PROC-TR])。如果配置项是“计划”这类文件,则需要项目经理(或上级领导)的审批。

  • 若配置项通过了技术评审或领导审批,则转向[Step4],否则转向[Step2]

[Step4] 正式发布

  • 配置项通过技术评审或领导审批之后,则配置项的状态从“草稿”变迁为“正式发布”,版本号格式为X.Y。

[Step5] 变更

  • 修改处于“正式发布”状态的配置项,必须按照“变更控制规程”执行,主要步骤如下(详见变更控制规程):

  • 如果CCB同意变更,则配置项状态从“正式发布”变迁为“正在修改”。

  • 项目成员使用Checkout/Checkin功能,可以修改处于“正在修改”状态的配置项,版本号格式为X.YZ。

  • 修改完毕后,该配置项要重新接受技术评审或领导审批,转向[Step3]

17.4 配置项变更控制

17.4.1 目的

  • 防止配置项被随意修改而导致混乱。

17.4.2 角色与职责

  • CCB对审批变更申请。

17.4.3 启动准则

  • 待变更的配置项状态为“正式发布”,或者该配置项已经成为某个基线的一部分(即被“冻结”)。

17.4.4 输入

  • 待变更的配置项

17.4.5 主要步骤

[Step1] 变更申请

  • 变更申请人向CCB提交变更申请,重点说明“变更内容”和“变更原因”。

[Step2]审批变更申请

  • CCB审批该申请,分析此变更对项目造成的影响。如果同意变更,则转向[Step3],否则终止本规程。

补充说明:一个配置项的变更可能导致其它配置项也发生变更,CCB在审批变更申请时一定要考虑这些问题。

[Step3] 安排变更任务

  • CCB指定变更执行人,安排他们的任务。CCB需要和变更执行人就变更内容达成共识。

补充说明:变更执行人可能是变更申请人,也可能不是。

[Step4]执行变更任务

  • 变更执行人根据CCB安排的任务,修改配置项。

  • CCB监督变更任务的执行,如检查变更内容是否正确、是否按时完成工作等。

[Step5] 对更改后的配置项重新进行技术评审(或审批)

  • 如果配置项是技术文档,则需要接受技术评审(参见技术评审规程[SPP-PROC-TR])。如果配置项是“计划”这类文件,则需要项目经理(或上级领导)的审批。

  • 若配置项通过了技术评审或领导审批,则转向[Step6],否则转向[Step4](即重新修改)。

[Step6]结束变更

  • 当所有变更后的配置项都通过了技术评审或领导审批,这些配置项的状态从“正在修改”变迁为“正式发布”。CCB在《配置项变更控制报告》中签字,结束变更。

17.4.6 输出

  • 本规程的所有信息都记录在《配置项变更控制报告》中。

17.4.7 结束准则

  • CCB签字结束变更。

17.4.8 度量

  • CCB统计变更工作量。

17.5 实施建议

  • 要求所有人员对其工作成果进行配置管理。

  • 对全员进行配置管理培训。

  • 由于配置库里保存的是项目的所有工作成果,应当选择“责任心强、可靠”的人员担任配置管理员。

选用合适的软件工具,尽量减少配置管理过程的工作量。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/165035.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

42. 【农产品溯源项目前后端Demo】后端-区块链连接服务

本节介绍后端代码是如何与区块链网络连接的。 1.在后端代码里fabric包 负责与区块链网络连接,并发送交易。 2.fabric.Const文件 定义 区块链网络拓扑结构,请查看注释。 public final class Const {//区块链网络中organizations的配置目录,从配置文件读取证书目录public stat…

【JavaEE】单例模式如何保证在多线程环境下线程安全高可用?

文章目录1 单例模式回顾2 饿汉式单例模式的实现3 懒汉式单例模式的实现4 单例模式的线程安全问题分析5 线程安全的懒汉式实现6 总结1 单例模式回顾 单例模式是设计模式的一种。而设计模式就是针对我们实际开发中写代码所遇到的不同场景所设立的解决方案。在笔者JavaSE阶段的文章…

Vue组件化编程需要注意的命名规则

在Vue组件化编程过程中,开始接触的不太注意命名规则,比如对于组件的内部参数命名以及在父组件中使用命名感到模糊,犯一些错误,就感觉在踩坑。 其实,这是对Vue组件化编程中的命名规则没有留意,稍加学习就可以…

java伪随机数生成器

关于随机数的基本概念 1、对随机数性质分类: 随机性:符合该性质的叫弱伪随机数。这种随机数仅可以用于一般应用,无法用在密码学,例如java中的java.util.Random类不可预测性:符合该性质的叫强伪随机数。在密码学中&am…

学习记录660@项目管理一般知识

看了项目管理一般知识这一章的知识,最开始觉得这些内容,觉得太过于书面化,比如关于什么是项目管理,都要用一段正式定义,充满了国内教育的繁琐感,但是细细品味觉得这些定义是很有道理的,并不是多…

保障接口数据安全的十种方案

视频介绍 数据加密 --主要针对网络抓包 AES 对称加密 RES 非对称加密 实践中直接使用 HTTPS 对于用户个人信息及密码等敏感信息 可额外进行加密 (如密码会进行md5加密防止撞库) 加签验签 --甄别数据在传输过程中被篡改 通常通过哈希算法 进行验证 需…

【学习笔记】【Pytorch】十、搭建CIFAR-10 model结构和Sequential的使用

【学习笔记】【Pytorch】十、搭建CIFAR-10 model结构和Sequential的使用学习地址主要内容一、CIFAR-10 model结构介绍二、代码实现学习地址 PyTorch深度学习快速入门教程【小土堆】. 主要内容 一、CIFAR-10 model结构介绍 input : 332x32,3通道32x32的图片 -->…

kubernetes学习-快速上手速查手册

目录使用k3s快速搭建k8s安装k8s dashboard使用Helm部署K8S资源k8s核心命令一切推倒重来资源创建方式NamespacePodDeploymentServiceIngressConfigMapJob数据持久化搭建NFSPV和PVC使用k3s快速搭建k8s 官网地址https://www.rancher.cn/k3s/ k3s是一个轻量级的k8s,拥…

【SpringCloud12】Gateway服务网关

1.概述简介 1.1官网 1.Zuul 1.X 2.Gateway 1.2是什么 Cloud全家桶中有个很重要的组件就是网关,在1.x版本中都是采用的Zuul网关;但在2.x版本中,zuul的升级一直跳票,SpringCloud最后自己研发了一个网关替代Zuul,那就…

uboot下识别FAT32格式的U盘报错:## Valid DOS partition found ##

1、出错的现象 (1)U盘被格式成FAT32文件系统,在Windows和Linux系统中都可以正常识别并挂载,在uboot下可以正常识别但是不能挂载; (2)在uboot下使用usb命令可以探测到U盘,但是用fatls、fatinfo等命令去挂载U盘时会失败,…

Spring MVC+Spring+Mybatis实现支付宝支付功能

本教程详细介绍了如何使用ssm框架实现支付宝支付功能。本文章分为两大部分,分别是「支付宝测试环境代码测试」和「将支付宝支付整合到ssm框架」,详细的代码和图文解释,自己实践的时候一定仔细阅读相关文档,话不多说我们开始。 本…

永磁同步电机(PMSM)磁场定向控制(FOC)转速环PI调节器参数整定

文章目录前言一、调节器的工程设计方法二、转速环PI调节器的参数整定2.1.转速环的结构框图2.2.典型II型系统2.3.转速环PI参数整定计算公式三、转速环PI调节器设计实例3.1.永磁同步电机磁场定向的转速外环电流内环双闭环控制3.2.转速环PI参数计算3.3.仿真分析总结前言 本章节采…

【2022年度总结2023新年Flag】--2022:高考失利,我奋力奔跑的大一上;2023,朝着成为更优秀的自己迈进ing

🌱博主简介:是瑶瑶子啦,一名大一计科生,目前在努力学习C进阶,JavaSE。热爱写博客~正在努力成为一个厉害的开发程序媛! ✈往期博文回顾:【C语言篇】请把这篇文章推给现在还对指针一知半解的童鞋超生动图解,详…

linux w5500 驱动及使用

1、驱动 驱动来源: a. 内核:linux内核w5500驱动,包含两个源文件w5100.c和w5100-spi.c /kernel/drivers/net/ethernet/wiznet/w5100.c kernel/drivers/net/ethernet/wiznet/w5100-spi.c kernel/drivers/net/ethernet/wiznet/w5100.h 可通过make menuconfi…

Django 入门学习

记录Django入门学习过程 1 基本环境 安装virtualenv pip3.9 install virtualenv 使用命令行创建 创建一个项目 virtualenv dj 进入虚拟环境 cd dj/bin source ./activate 进入成功后bash前面显示括号 安装 Django pip install django3.0.6 安装成功后之星django-…

创建者模式

1.单例模式 单例模式能够保证一个类只有一个实例,并且提供一个可以访问该实例的全局节点 实现步骤 类中添加一个私有静态成员变量用于保存单例实例声明一个公有静态构建方法用于获取单例实例在静态方法中实现"延迟初始化"。 该方法会在首次被调用时创建一…

【云原生kubernetes】k8s中pod使用详解

一、前言 在之前k8s组件一篇中,我们谈到了pod这个组件,了解到pod是k8s中资源管理的最小单位,可以说Pod是整个k8s对外提供服务的最基础的个体,有必要对Pod做深入的学习和探究。 二、再看k8s架构图 为了加深对k8s中pod的理解&#x…

ARM PWM 定时器与实战

一、什么是定时器(timer) 1、定时器是 SoC 中常见外设 (1) 定时器与计数器。计数器是用来计数的(每隔一个固定时间会计一个数);因为计数器的计数时间周期是固定的,因此到了一定时间只要用计数值计数时间周…

contex-m基于IAR工程从boot阶段引导app

目录 1.修改工程 2.修改代码 Boot代码 App代码 3.修改FM33LG04x.icf 4.修改IAR工程icf配置路径 5.修改FM33LG04X.icf链接文件 6.编译工程 7.查看map文件 8.调试程序 1.修改工程 本次调试的demo为《UART0 DMA发送_串口中断示例》,以下修改都是基于该工程&…

初始C语言 - 函数

C语言中函数的分类: 1.库函数:C语言自带的函数,包含大量频繁使用的功能 2.自定义函数:有些库函数没有的,需要程序员自己设计一、库函数通过MSDN、cplusplus.com、cppreference.com这些网站,查看学习函数的作用和用法在使用库函数时…