整合现有软件配置管理系统

2024-05-01 05:48

本文主要是介绍整合现有软件配置管理系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

整合现有软件配置管理系统
1.软件配置管理现状
大多数大型外包公司的运营方式是以项目为单位,SCM也分散在各个项目内节点。

 
SCM的节点信息只有本项目内人员知道。SCM类型各异:CVS,ClearCase,VSS,Perforce等。项目结束后,各SCM下落不明。
2.软件配置管理统一化的各种提案
2.1 完全统一化
在全公司,或者各Group内,使用一种SCM系统,并在该系统上分配给各个项目SCM,和权限。这种提案的优点是:
1.由某个部门例如IT,统一管理,统一分配;
2.更完备的权限控制;
3.统一的备份机制更有效的资产保护;
4.公司内所有员工都了解SCM的信息,更有利于资产的重用。
然而,完全统一化存在很多弊端。
1.客户指定SCM类型。各项目客户可能会指定SCM的类型,统一化比较困难。
2.统一需要一个健壮的大型SCM系统,例如ClearCase,然而ClearCase的普及需要相当长的时间和成本。
3.公司需要额外的人员管理和维护,需要ClearCase的专家负责培训,成本高。
4.一旦发生故障会影响所有项目的进程。
2.2 局部统一化
缩小统一化的范围,根据项目性质的不同,例如,需要使用ClearCase的项目,需要使用VSS项目,需要使用CVS的项目,各项目可以申请不同的SCM系统。各SCM系统可以选择性安装在不同的节点。成立SCM管理组织,各个节点的管理员由该组织管理,管理员可以兼职。但各节点的信息必须公开。这种提案的优点是:
1.由SCM组织统一管理,统一分配;
2.更完备的权限控制;
3.公司内所有员工都了解SCM的信息,更有利于资产的重用;
4.无需附加人员成本;
5.缩小了SCM系统故障的影响程度;
6.SCM类型可由项目组灵活选择。
然而,局部统一化也存在弊端。
1.SCM系统发生故障仍然会影响一部分项目的正常运行;
2.SCM管理组织的工作量无法预计;例如,新项目的配置,权限管理,数据备份等,硬件维护。
2.3 整合现有SCM
该提案不需要改动现有的SCM,而是将各个SCM节点的都收录到统一的目录系统内。SCM目录系统公开与众,任何人都可以访问目录系统。仍然需要SCM组织,但该组织不再维护实际的SCM,他们的工作是将SCM的信息收录到SCM
目录系统内。
这种提案的优点是:
1.没有额外的软硬件费用;
2.公司内所有员工都了解SCM的信息;
3.某项目的SCM的故障不会影响其他项目;
4.SCM类型可由项目组灵活选择;
5.减少SCM组织工作量;
6.更符合客户安全需求。
该提案的前提是:
项目各SCM节点都可以在企业内通过网络访问。
该提案存在问题有:
1.项目结束后,SCM节点的处理不明;
2.目录系统的搭建的成本;
3.分散的SCM不能被统一管理,存在数据丢失隐患,权限的滥用。
3.总结
将这3个提案进行比较,结果如下:
完全统一化
局部统一化
整合现用SCM
统一管理,统一分配
X
完备的权限控制
X
SCM的信息公开
SCM类型的可选性
X
统一的备份机制
X
管理和维护成本低
X
X
SCM系统故障影响度低
X
X
无需额外软硬件成本
X
X
资产的有效保存
X
4.建议
以低成本运营为主体的外包公司,建议采用“整合现用SCM”方案为现有SCM各节点编辑目录,并将目录公开,为了能有效地保存SCM管理的资产,建立公司内统一的SCM备份机制,由各项目成员定期将SCM内数据备份到公司统一的备份节点,并建议公司内独立的SCM用于保管已结束项目资源。
 

这篇关于整合现有软件配置管理系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950846

相关文章

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Linux系统之dns域名解析全过程

《Linux系统之dns域名解析全过程》:本文主要介绍Linux系统之dns域名解析全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、dns域名解析介绍1、DNS核心概念1.1 区域 zone1.2 记录 record二、DNS服务的配置1、正向解析的配置

SpringBoot整合jasypt实现重要数据加密

《SpringBoot整合jasypt实现重要数据加密》Jasypt是一个专注于简化Java加密操作的开源工具,:本文主要介绍详细介绍了如何使用jasypt实现重要数据加密,感兴趣的小伙伴可... 目录jasypt简介 jasypt的优点SpringBoot使用jasypt创建mapper接口配置文件加密

SpringBoot整合MybatisPlus的基本应用指南

《SpringBoot整合MybatisPlus的基本应用指南》MyBatis-Plus,简称MP,是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,下面小编就来和大家介绍一下... 目录一、MyBATisPlus简介二、SpringBoot整合MybatisPlus1、创建数据库和

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重