软件配置管理(三)软件配置管理核心功能

文章目录

  • 一、CMM/CMMI与软件配置管理
      • 产品完整性
  • 二、三库管理
  • 三、基线管理
      • 基线管理的好处
      • 基线管理的步骤
  • 四、配置库管理
  • 五、变更管理
      • 变更管理流程
  • 六、配置审计
  • 七、配置状态报告

一、CMM/CMMI与软件配置管理

软件配置管理是CMM/CMMI二级(可重复级)的一个重要KPA。
CMM/CMMI又将软件配置管理的目的定义为建立和维护产品的完整性

产品完整性

项目提交的工作成果是产品集合完整子产品正确的。

  • 产品集合完整:产品包含的子产品是完整的;
  • 子产品正确:子产品达到了需求要求,满足标准、规程的要求。

二、三库管理

配置项在开发库受控库产品库之间迁移,一级比一级的控制更加严格。
在CMM中,对开发库的管理没有要求,但要对受控库和产品库进行管理。

  • 开发库
    存放开发过程中需要保留的各种信息,供开发人员专用;
  • 受控库
    在软件开发某个阶段工作结束后,将产品或有关信息存入;
  • 产品库
    在软件产品完成系统测试后,作为最终产品存入库内。

在这里插入图片描述
按照三库管理的思路,软件开发组日常的工作在开发库中开展,当工作达到里程碑时,再迁移到受控库,在受控库中经过更加严格的测试后,再上升到产品库,最后发布。
三库间通常通过权限与流程控制实现配置项再不同库之间的流转以及人员访问。即逻辑独立,物理上在一起

三、基线管理

每个基线都接受配置管理的控制,对其的修改将按照变更控制的要求进行。在一个软件开发阶段结束时,上一个基线加上增加和修改的内容形成下一个基线。

基线管理的好处

  • 重现性:及时返回并重新生成软件系统版本的能力。
  • 可追踪性:建立项目工作之间的前后继承关系。
  • 版本隔离:基线为开发工件提供了一个定点和快照,新项目可以中基线提供的定点中建立。

基线管理的步骤

  1. 在开发前确定基线的配置
  2. 在批准基线前,根据配置检查配置项的完整性
  3. 对每个配置项,确定版本的正确性
  4. 为每个配置项建立基线标志
  5. 基线变更管理
  6. 基线报告和审计信息

四、配置库管理

每个配置项从建立开始,就被划分成3个分支:私有分支集成分支公共(主干)分支,分别对应三类工作空间,由CMO统一管理。

  • 私有分支:是开发人员的私有开发空间,除该开发人员外,其他人无权操作;
  • 集成分支:对应开发团队的公共空间,开发团队拥有读写权限,而其他成员只有只读权限,SIO和相关指定负责人进行管理;
  • 公共分支:对应整个软件开发组织的公共空间。对全体人员只开发只读权限,由SIO负责管理。

决定配置库的结构是配置管理活动的重要基础,一般常用的是两种组织形式:按配置类型分类建库和按任务建库。

五、变更管理

保证配置项在开发过程中始终处于受控状态,且在任何情况都能迅速恢复到任一历史状态。
为了更好知道变更范围的影响分析,可以通过《需求追踪表》和《配置项依赖关系表》发现受到影响的内容。

变更管理流程

  1. 提出变更请求
  2. CCB审核并决定是否批准
  3. 分配人员,提取SCI,进行修改
  4. 提交修改后的SCI,并测试
  5. 重建软件版本
  6. 复审所有SCI的变化
  7. 发布新版本

六、配置审计

作为变更控制的补充手段,确保变更需求已被切实实现。审计机制保证修改的动作被完整地记录。
配置审计有两种,分别是物理审计和功能审计。

  • 物理审计(PCA):检查版本是否正确一致(完整性)。一般由非配置管理人员进行,如SQA(质量保证人员)
    • 配置项是否齐备
    • 版本是否齐全
  • 功能审计(FCA):检查配置项是否完整,各种过程文档是否齐备、正确、与需求是否一致(一致性),归结为两点,即完全和齐备。一般由CMO进行。

七、配置状态报告

配置状态报告就是根据配置项操作的记录来向管理者报告软件开发活动的进展情况。通常是定期进行、通过case工具自动生成的。着重反应当前基线配置项的状态,对变更情况和配置库情况也应进行说明。

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

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

相关文章

移除指定 global using 命名空间

前言在《.NET 6新特性试用 | 隐式using指令》中&#xff0c;我们介绍过&#xff0c;开启隐式using指令时&#xff0c;会在编译时生成 GlobalUsings.g.cs 文件&#xff0c;加入大量 global using 指令&#xff1a;// <auto-generated/> global using global::Microsoft.As…

Ubuntu 每日技巧- 自动备份Ubuntu 14.04到Box云存储上

Ubuntu 每日技巧- 自动备份Ubuntu 14.04到Box云存储上 如今你已经升级或者安装了Ubuntu 14.04&#xff0c; 但是还有另外一件保护你的新系统需要做的事情&#xff1a;备份&#xff01; Ubuntu内置了一个备份工具 Dj Dup Backup Tool。它允许你备份你的系统并保存在本地或者通过…

【C#/.NET 日常开发技巧】JWT+ActionFilter 简便控制器代码

微信公众号&#xff1a;趣编程ACE关注可了解更多.NET日常开发技巧&#xff0c;如需源码&#xff0c;请公众号留言 源码;JWTActionFilter 简便控制器代码这是微软关于过滤器的介绍&#xff1a;https://docs.microsoft.com/zh-cn/aspnet/core/mvc/controllers/filters?viewaspne…

在P2P市场中代替“看不见的手”的算法在哪里

◆ ◆ ◆ 本文简单探讨P2P市场机制&#xff0c;在此基础上探讨匹配撮合服务的可能性。 ◆ ◆ ◆ P2P市场机制基本定义与假设 首先&#xff0c;我们回顾一些基本定义与假设。P2P市场为“网络借贷是指个体和个体之间通过互联网平台实现的直接借贷。”[2]利率决定一般是平台决定借…

关于他们回答的 怎样在桌面建一个python GUI的快捷方式 这个问题

在之前的2个随笔里面&#xff0c;有写过《找到可以解决问题的正确的人》、《如何提问》&#xff0c;说白了就是您需要帮助的时候&#xff0c;您得让对方100%懂你&#xff0c;否则没戏。 那么最近看到这样1个古老的问题&#xff0c;和一些没有答到"点儿"上的回答&…

.NET Core中行为过滤器ActionFilterAttribute的使用介绍

什么是行为过滤器&#xff1f;行为过滤器是你可以应用到一个控制器行为的&#xff0c;或者整个控制器的&#xff0c;来修改控制器行为的执行方式的属性。当请求进入 API 接口的时候&#xff0c;操作过滤器提供了一个进入之前&#xff08;before&#xff09;和进入之后&#xff…

基本线程同步(三)在同步的类里安排独立属性

声明&#xff1a;本文是《 Java 7 Concurrency Cookbook 》的第二章&#xff0c;作者&#xff1a; Javier Fernndez Gonzlez 译者&#xff1a;许巧辉 校对&#xff1a;方腾飞 在同步的类里安排独立属性 当你使用synchronized关键字来保护代码块时&#xff0c;你必须通过一…

软件项目组织管理(一)项目管理概述

文章目录什么是项目项目的特征项目的组成要素&#xff08;三维约束&#xff09;什么是项目管理什么是IT项目什么是软件项目管理项目管理的目标&#xff08;项目成功的标志&#xff09;软件项目失败的原因活动的3个基本特点人类活动分为两种类型作业和项目的区别&#xff08;必考…

ABP Framework 5.2 RC 版本发布及新增功能介绍

本文将介绍 ABP Framework 5.2 RC 版新增的主要功能&#xff1a;•单层解决方案模板•API 版本控制•源代码控制移除libs文件夹•对 Swagger UI 隐藏 ABP 默认端点•CMS Kit应用模块自定义全局 CSS 和 JavaScript关注 ABP Framework 最新开发进度&#xff0c;后面还会陆续发布新…

《计算机组成原理》----2.3 二进制运算

本节书摘来自华章出版社《计算机组成原理》一书中的第2章&#xff0c;第2.3节&#xff0c; 作 者 Computer Organization and Architecture: Themes and Variations&#xff3b;英&#xff3d;艾伦克莱门茨&#xff08;Alan Clements&#xff09; 著&#xff0c;沈 立 王苏峰…

JTable常见用法细则

JTable是Swing编程中很常用的控件,这里总结了一些常用方法以备查阅.欢迎补充,转载请注明作者与出处.一.创建表格控件的各种方式:1) 调用无参构造函数. JTable table new JTable();2) 以表头和表数据创建表格. Object[][] cellData {{"row1-col1", "row1-col…

下拉刷新:继承listView控件

1、首先初始化的时候给控件监听OnScrollListener&#xff0c;其中onScroll的参数里得到第一个显示的条目&#xff0c;当第一个条目为0的时候就可以执行下啦刷新了。第二覆写的方法是 onScrollStateChanged就是滑动状态的监听&#xff0c;3种状态都是常量&#xff1a;快速滑动&a…

软件项目组织管理(二、三)项目管理与信息技术环境、项目管理过程组

文章目录系统方法系统管理三维模型组织环境组织的四个框架组织的结构项目生命周期管理评审虚拟团队什么是过程项目管理过程组系统方法 项目管理工作需要采取系统的方法&#xff0c;描述在解决复杂问题时所需的整体性和分析性方法。 系统哲学&#xff1a;将事情作为系统考虑的…

《编译与反编译技术》—第1章1.7节C语言程序的编译流程

本节书摘来自华章出版社《编译与反编译技术》一书中的第1章&#xff0c;第1.7节C语言程序的编译流程&#xff0c;作者庞建民&#xff0c;陶红伟&#xff0c;刘晓楠&#xff0c;岳峰&#xff0c;更多章节内容可以访问云栖社区“华章计算机”公众号查看。1.7 C语言程序的编译流程…

Base64

2019独角兽企业重金招聘Python工程师标准>>> Base64是一种基于64个可打印字符来表示二进制数据的表示方法。由于2的6次方等于64&#xff0c;所以每6个比特为一个单元&#xff0c;对应某个可打印字符。三个字节有24个比特&#xff0c;对应于4个Base64单元&#xff0c…

软件配置管理(六)常用配置软件配置工具指令

文章目录软件配置管理工具的主要功能两种版本控制模型Lock-Modify-UnlockCopy-Modify-MergeSubversionGit软件配置管理工具的主要功能 版本控制变更管理配置审核配置状态统计问题跟踪访问控制和安全控制 两种版本控制模型 Lock-Modify-Unlock “加锁-修改-解锁”模型 对于版…

.NET 6 攻略大全(一)

点击上方蓝字关注我们&#xff08;本文阅读时间&#xff1a;15分钟)欢迎使用 .NET 6。今天的版本是.NET 团队和社区一年多努力的结果。C# 10 和 F# 6 提供了语言改进&#xff0c;使您的代码更简单、更好、性能大幅提升&#xff0c;我们已经看到微软降低了托管云服务的成本。.NE…

Win7下JDK环境变量的设置

JDK并不像Microsoft阵营vs那样智能&#xff0c;安装好后所有的东西都给你配置好了&#xff0c;我们还没需要手动配置很多东西 首先说为什么要配置JDK的环境变量在任何路径下识别java命令和java类 配置分为2个部分&#xff0c;1&#xff0c;java命令路径。2,java加载类 分为3个步…

简单模拟实现简单的当登录延时的效果

①、先建立一个activaty去部署我们的登陆界面 1 package com.example.administrator.actionbardemo;2 3 import android.app.Activity;4 import android.content.Intent;5 import android.os.Bundle;6 import android.view.View;7 import android.widget.Button;8 import andro…

《音乐达人秀:Adobe Audition实战200例》——实例11 录制任意音量音乐

本节书摘来自异步社区《音乐达人秀&#xff1a;Adobe Audition实战200例》一书中的第2章&#xff0c;实例11 &#xff0c;作者 健逗&#xff0c;更多章节内容可以访问云栖社区“异步社区”公众号查看。 实例11 录制任意音量音乐 这个实例将讲解如何任意控制录音过程中的音量。你…