版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第8章
软件维护与演化学习目标•了解软件维护的类型•掌握软件维护的基本流程•熟悉软件部署的基本方法•掌握软件部署工具的使用方法•了解软件配置管理的基本概念•熟悉常用软件配置管理工具的使用方法
软件演化是指对软件进行维护和更新的一种行为,它是软件生命周期中始终存在的变化活动。软件演化可分为开发演化和运行演化。开发演化是创造一个新软件的过程,在一定的约束条件下从头开始实施。运行演化又称软件维护,是软件系统交付使用以后,为了改正错误或满足新的需要而修改软件的过程,一般是在现有系统的限定和约束条件下进行。软件演化过程包括了软件维护与更新、软件部署、软件配置管理等内容。软件维护与更新1软件部署2软件配置管理38.1软件维护与更新软件维护是软件生命周期中的最后一个阶段,也是历时最长的一个阶段,从系统投入生产运行以后一直持续到软件生命周期结束。
软件维护是指软件系统交付使用以后,为了改正软件运行错误,或者为了满足新的需求而加入新功能的修改软件的过程,以保证软件的日常良好运行。软件维护与更新软件的可维护性是指软件能够被理解,并能纠正软件系统出现的错误和缺陷,以及为满足新的要求进行修改、扩充或压缩的容易程度。(1)可理解性(2)可测试性(3)可修改性(4)可靠性(5)可移植性(6)可使用性(7)效率8.1.1软件的可维护性8.1软件维护与更新(1)改正性维护软件在交付使用后,难免存在软件自身隐含的错误及软件缺陷。改正性维护就是为了改正潜藏及遗留下来的错误而进行的活动。(2)适应性维护适应性维护是指使软件适应技术变化和管理需求变化而进行的修改。(3)完善性维护完善性维护是为扩充功能和改善性能而进行的修改,主要是指对已有的软件系统增加一些在系统分析和设计阶段中没有规定的功能与性能特征。这些功能对完善系统功能是非常必要的。另外,还包括对处理效率和编写程序的改进。8.1.2软件维护类型8.1软件维护与更新(4)预防性维护预防性维护是指为了改进应用软件的可靠性和可维护性,为了适应未来的软、硬件环境的变化,主动增加预防性的新的功能,使应用系统适应各类变化而不被淘汰。图8-1四种维护类型的占比8.1软件维护与更新可维护性特性改正性维护适应性维护完善性维护可理解性√可测试性√可修改性√√可靠性√可移植性√可使用性√√效率√表8-1七种特性在各类维护中的侧重点8.1软件维护与更新8.1.3软件维护流程图8-2软件维护基本流程8.1软件维护与更新通常软件维护执行以下步骤:(1)提交维护申请。(2)选择符合申请的维护类型。(3)分析修改的内容及必要性,确认修改后对原有系统的影响程度。(4)审核同意或否决维护申请。(5)为每个提交的维护申请排优先级,并且安排工作进度及人员。(6)修改代码,记录所修改的内容并评审,保证程序运行正常。8.1软件维护与更新(7)评审编码情况,详细填写维护工作记录表。(8)不仅测试所修改的部分,还要对其他部分进行全面测试,确认是否对其他部分有影响。(9)必须保持程序与文档的一致性,应实时更新相关文档。(10)软件版本发布,确保发布后的程序可在系统程序中安全运行。(11)每日查看数据库备份情况,并定期完成数据清理。8.1软件维护与更新(1)软件维护的困难
①文档缺失、不充分或过期②软件升级频繁③软件维护人员变动④未严格遵守软件开发标准8.1.4软件维护的困难及对应策略8.1软件维护与更新(2)提高软件可维护性的途径①可理解的系统结构设计②标准化的程序设计语言③结构化的文档④有效的软件维护管理⑤明确软件质量目标及优先级⑥明确的质量保证审查8.1.4软件维护的困难及对应策略8.18.2软件部署软件部署是一个复杂过程,包括从开发者发放产品,到用户在他们的计算机上实际安装并维护应用的所有活动。这些活动包括开发者的软件打包,企业及用户对软件的安装、配置、测试、集成和更新等。软件部署工具可以帮助软件开发团队更好地编写代码、进行测试、让软件在其环境中运行并定期更新。比较常用的工具包括:Docker、Terraform、Ansible、Packer、Kubernetes等。8.2.1软件部署的概念软件部署Docker是近年来较为流行的软件部署工具之一,它是一个开源的应用容器引擎,基于Go语言并遵从Apache2.0协议开源。Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。其中容器完全使用沙箱机制,相互之间不会有任何接口,且容器性能开销极低。8.2.2软件部署工具Docker8.2软件部署(1)Docker架构图8-3Docker架构8.2软件部署部件作用Docker镜像(Images)Docker镜像是用于创建Docker容器的模板Docker容器(Container)容器是独立运行的一个或一组应用Docker客户端(Client)Docker客户端通过命令行或者其他工具使用DockerAPI与Docker的守护进程通信。Docker主机(Host)一个物理或者虚拟的机器,用于执行Docker守护进程和容器Docker仓库(Registry)Docker仓库用来保存镜像,可以理解为代码控制中的代码仓库DockerMachineDockerMachine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装DockerDocker守护进程(Daemon)Daemon作为服务器端接受来自客户的请求,并处理这些请求表8-2Docker各部件作用8.2软件部署Docker优点:①持续集成②可移植性③版本控制④隔离性
⑤安全性8.28.3软件配置管理软件配置管理(SoftwareConfigurationManagement,简称SCM)应用于整个软件工程过程。在软件建立时变更是不可避免的,而变更加剧了项目中软件开发者之间的混乱。SCM活动的目标就是为了标识变更、控制变更、确保变更正确地实现,并向其他有关人员报告变更。软件配置管理包括六个子域,即软件配置管理过程管理、软件配置标志、软件配置控制、软件配置状态统计、软件配置审核、软件发行管理和交付。软件配置管理如何应对软件变更所带来的文档及程序代码变化的情况,软件配置管理起到了关键性的作用:(1)版本控制(2)并行开发(3)变更控制(4)配置管理8.3.1软件配置管理的作用8.3软件配置管理通过控制、记录、追踪对软件的修改和每个修改生成的软件组成部件来实现对软件产品的管理功能。(1)制订配置管理计划(2)配置库管理(3)版本控制(4)变更控制(5)配置审计8.3.2软件配置管理过程8.3软件配置管理目前,软件工程领域常见的软件配置管理工具有IBMRationalSoftware提供的ClearCase、Microsoft提供的VSS(VisualSourceSafe)、CollabNet提供的SVN(Subversion)以及Github等。(1)VisualSourceSafe(VSS)8.3.3常用的软件配置管理工具图8-4VSS6.0工作界面8.3软件配置管理(2)Subversion(SVN)图8-5SVN集中式管理工作流程8.3软件配置管理(3)GitHubGitHub是一个面向开源及私有软件项目的托管平台,支持Git作为唯一的版本库格式进行托管,并提供一个web界面。通过使用Git来操作GitHub实现代码的共享。图8-6本地仓库组成8.3软件配置管理图8-7Git中文件流通图8.3本章结束!第9章软件项目管理本章学习目标1.了解软件工程项目管理的相关知识。2.了解软件团队管理的基本方法。3.熟悉需求变更管理的基本方法。4.熟悉常用软件工程中计划与估算方法。5.熟悉软件项目风险管理的基本方法。6.掌握软件项目管理计划的制定方法
软件项目管理
为使软件项目开发获得成功,关键问题是要掌握软件项目的工作范围、可能风险、需要的资源(人、硬件、软件)、要实现的任务、经历的里程碑、花费工作量(成本)、进度安排等。软件项目管理在技术工作开始之前就应当开始,在软件从概念到实现的过程中继续进行,当软件工程过程最后结束时才终止。软件项目管理是为了使软件项目能够按照预定的成本、进度、质量顺利完成,而对人员(People)、产品(Product)、过程(Process)和项目(Project)进行分析和管理的活动。软件工程项目管理1计划与估算2软件项目团队管理39.1软件工程项目管理软件工程项目管理的介绍软件工程项目管理是指在软件开发过程中对项目的规划、组织、指导和控制,以确保项目按时、按质高效完成的管理活动。大型软件项目需要庞大的开发团队来进行协作和开发,包括开发人员、测试人员、项目经理、业务分析师等。同时,大型软件项目涉及多个团队和多个利益相关者,需要跨团队和跨部门的沟通和协作,管理工作量较大。对于这样庞大的项目如果没有管理,其质量保障是难以想象的。在软件工程项目管理方面比较权威的体系是项目管理知识体系(ProjectManagementBodyofKnowledge,简称PMBOK),它是由美国项目管理协会(ProjectManagementInstitute,简称PMI)发起的。9.1.1项目启动管理项目启动时一般需要明确以下几个问题:(1)项目范围、项目周期、关键里程碑点。(2)识别相关人员,明确沟通、汇报渠道及各个角色的职责。(3)项目规则约定、表单模板、流程。(4)项目资源、费用预算。(5)产品业务需求、技术需求,以及用户群体。(6)识别可能存在的项目风险。(7)需要什么样的技术支持,是否需要前期学习和调查。9.1.2项目计划管理
项目计划管理是在项目计划阶段对项目实施的管理,包括范围管理、进度管理和综合管理。一个科学的计划,不仅可以保证项目工期,减少资源浪费,还可以对项目的进程进行跟踪控制管理,从而保证项目的按期完成。
项目计划应在项目开始初期制定出来,并随着工程的进展渐进明细。(1)开发进度计划制订识别活动识别活动依赖关系估算活动资源为活动分配人员创建进度图表图9-1项目进度安排9.1.2项目计划管理图9-2项目进度计划甘特图(2)计划跟踪与监控
计划做得再好,如果没有有效执行,也等于没做。项目进度跟踪与控制过程需要采用日志的方式或相应的工具,让项目组成员每天填写工作完成情况。9.1.3人员组织与管理
人员是软件工程项目中最重要、最为活跃的资源因素。如何组织得更加合理,管理得更加有效,从而最大限度地发挥这一重要的资源潜力,对于软件项目的成功至关重要。高效的开发团队一般具有以下特征:(1)具有明确和挑战性的共同目标(2)团队具有很强的凝聚力(3)具有融洽的交流环境(4)具有共同的工作规范和框架(5)采用合理的开发过程9.1.4变更管理
需求变更可能发生在任何阶段,即使到项目后期也会存在。后期的变更往往会对项目产生一些负面的影响。需求变更是软件开发过程中开发人员和管理者们最为头疼的一件事情。9.1.4变更管理需求变更管理一般需要完成以下几个任务:(1)确定变更控制过程。确定一个选择、分析和决策需求变更的过程;所有的需求变更都需遵循此流程。(2)建立一个由项目风险承担者组成的软件变更控制委员会(SoftwareChangControlBoard,简称SCCB),由他们来评估和确定需求变更。(3)进行变更影响分析,评估需求变更对项目进度、资源、工作量和项目范围以及其他需求的影响。(4)跟踪变更影响的产品,当进行某项需求变更时,根据需求跟踪矩阵找到相关的其他需求、设计文档、源代码和测试用例;这些相关部分可能也需要修改。9.1.4变更管理(5)建立基准和控制版本;需求文档要确定一个基线,之后的需求变更遵循变更控制过程即可。(6)维护变更的历史记录;记录变更需求文档版本的日期、所做的变更及其原因,还包括由谁负责更新和更新后新版本号等情况。(7)跟踪每项需求的状态;状态包括“确定”“已实现”“暂缓”“新增”“变更”等,建立一个数据库,其中每一条记录一项需求。(8)衡量需求稳定性;记录基线需求的数量和每周或每月的变更(添加、修改、删除)数量。9.1.4变更管理表9-1需求变更申请表模板9.1.5风险管理软件项目风险是指在软件开发过程中遇到的预算和进度等方面的问题,以及这些问题对软件项目的影响。软件项目风险会影响项目计划的实现。如果项目风险变成现实,就有可能影响项目的进度,增加项目的成本,甚至使软件项目不能实现。如果对项目进行风险进行有效管理,就可以最大限度地减少风险的发生。项目风险管理可划分为识别风险、分析风险、规划风险应对和控制风险等过程。9.2计划与估算本节具体介绍两种类型的计划,一个是贯穿项目始终的计划,另一个是完成规格说明之后必须产生的详细计划。9.2.1计划项目计划完整地记录以下内容:要完成的工作,谁将执行此项工作,开发进度安排,以及项目的成果是什么。计划驱动开发基于工程项目管理技术,可以看作管理大型软件开发项目的传统方法。计划驱动的开发的问题是,由于软件开发和使用的环境的变化,必须修改许多早期的决策。项目计划较好的做法是将计划驱动方法和敏捷开发结合起来,其中的平衡取决于项目的类型和人员的技术水平。9.2.1计划(1)项目计划
在计划驱动的项目开发中,项目计划包括项目可用资源的分配、工作分解以及完成工作的进度安排。
多数的计划书应该包括以下几个部分:
①引言。
②项目组织。
③风险分析。
④硬件和软件资源需求。
⑤工作分解。
⑥项目进度安排。
⑦监控和报告机制。9.2.1计划(2)计划过程项目计划是一个迭代的过程,在项目的启动阶段,初始项目计划的创建就开始了。计划不可避免地会改变。由于在项目进行期间不断产生新的关于系统和项目团队的信息,所以必须经常性地修正原有计划,反映需求、进度安排以及风险的变更。9.2.2软件规模估算
9.2.2软件规模估算
用代码行技术度量软件规模,当程序较小时常用的单位是代码行数(linesofcode,简称LOC),当程序较大时常用的单位是千行代码数(kilolinesofcode,简称KLOC)。①代码行技术的优点a.代码行是所有软件开发项目都有的“产品”,而且很容易计算。b.许多现有的软件估算模型使用LOC或KLOC作为关键的输入数据。c.已有大量基于代码行的文献和数据存在。②代码行技术的缺点a.源程序仅是软件配置的一个成分,用它的规模代表整个软件的规模似乎不太合理。b.用不同语言实现同一个软件产品所需要的代码行数并不相同。c.这种方法不适用于非过程语言。9.2.2软件规模估算(2)功能点技术
功能点技术依据对软件信息域特性和软件复杂性的评估结果,估算软件规模。这种方法用功能点(functionpoints,简称FP)为单位,度量软件的规模。①信息域特性功能点技术定义了信息域的5个特性,分别是输入项数(Inp)、输出项数(Out)、查询数(Inq)、主文件数(Maf)和外部接口数(Inf)。a.输入项数:用户向软件输入的项数,这些输入给软件提供面向应用的数据。b.输出项数:软件向用户输出的项数,它们向用户提供面向应用的信息,如报表、屏幕、出错信息等。报表内的数据项不单独计数。c.查询数:所谓查询是一次联机输入,它导致软件以联机输出方式产生某种即时响应。d.主文件数:逻辑主文件(即数据的一个逻辑组合,它可能是某个大型数据库的一部分或是一个独立的文件)的数目。e.外部接口数:机器可读的全部接口(如磁带或磁盘上的数据文件)的数量,用这些接口把信息传送给另一个系统。9.2.2软件规模估算②估算功能点的步骤用下述3个步骤,可以估算出一个软件的功能点数(即软件规模)。a.计算未调整的功能点数(UFP)。首先,把产品信息域的每个特性(即Inp、Out、Inq、Maf和Inf)都分类成简单级、平均级或复杂级。根据其等级,为每个特性都分配一个功能点数。例如,一个平均级的输入项分配4个功能点,一个简单级的输入项是3个功能点,而一个复杂级的输入项分配6个功能点。9.2.2软件规模估算表9-4信息域特性系数值复杂级别复杂级别/特性系数简单平均复杂346457346710155710
9.2.2软件规模估算
9.2.2软件规模估算表9-5技术复杂性因子(TCF)序号Fi技术因素1F1数据通信2F2分布式数据处理3F3性能标准4F4高负荷的硬件5F5高处理率6F6联机数据输入7F7终端用户效率8F8联机更新9F9复杂的计算10F10可重用性11F11安装方便12F12操作方便13F13可移植性14F14可维护性9.2.2软件规模估算
计算机软件估算模型使用由经验导出的公式来预测软件开发的工作量。工作量是软件规模(LOC或FP)的函数,工作量的单位通常是人月(pm)。支持大多数估算模型的经验数据,都是从有限个项目的样本集中总结出来的。因此,没有一个估算模型能够适用于所有类型的软件和开发环境。1981年Boehm在《软件工程经济学》中首次提出了构造性成本模型COCOMO(ConstructiveCostModel)。1997年Boehm等人提出的COCOMO2模型,是原始的COCOMO模型的修订版,它反映了十多年来在成本估计方面所积累的经验。9.2.3工作量估算COCOMO2给出了3个层次的软件开发工作量估算模型,这3个层次的模型在估算工作量时,对软件细节考虑的详尽程度逐级增加。这些模型既可以用于不同类型的项目,也可以用于同一个项目的不同开发阶段。①应用系统组成模型:这个模型主要用于估算构建原型的工作量,模型名字暗示在构建原型时大量使用已有的构件。②早期设计模型:这个模型适用于体系结构设计阶段。③后体系结构模型:这个模型适用于完成体系结构设计之后的软件开发阶段。9.2.3工作量估算
9.2.3工作量估算9.2.3工作量估算表9-6成本因素及工作量系数成本因素级别甚低低正常高甚高特高产品因素要求的可靠性0.750.881.001.151.39
数据库规模
0.931.001.091.19
产品复杂程度0.750.881.001.151.301.66要求的可重用性
0.911.001.141.291.49需要的文档量0.890.951.001.061.13
平台因素执行时间约束
1.001.111.311.67主存约束
1.001.061.211.57平台变动
0.101.001.151.30
人员因素分析员能力1.501.221.000.830.67
程序员能力1.371.161.000.870.74
应用领域经验1.221.101.000.890.81
平台经验1.241.101.000.920.84
语言和工作经验1.251.121.000.880.81
人员连续性1.241.101.000.920.84
项目因素使用软件工具1.241.121.000.860.72
多地点开发1.251.101.000.920.840.78要求的开发进度1.291.101.001.001.00
9.2.3工作量估算9.2.3工作量估算COCOMO2使用的5个分级因素如下所述。①项目先例性:这个分级因素指出对于开发组织来说该项目的新奇程度。诸如开发类似系统的经验,需要创新体系结构和算法,以及需要并行开发硬件、软件等因素的影响,都体现在这个分级因素中。②开发灵活性:这个分级因素反映出为了实现预先确定的外部接口需求及为了及早开发出产品而需要增加的工作量。③风险排除度:这个分级因素反映了重大风险已被消除的比例。在多数情况下,这个比例和指定了重要模块接口(即选定了体系结构)的比例密切相关。④项目组凝聚力:这个分级因素表明了开发人员相互协作时可能存在的困难。它反映了开发人员在目标和文化背景等方面相一致的程度,以及开发人员组成一个小组工作的经验。⑤过程成熟度:这个分级因素反映了按照能力成熟度模型度量出的项目组织的过程成熟度。9.2.4软件项目管理计划的组成1简介1.1项目概述1.1.1意图、范围和目标1.1.2设想和限制1.1.3可交付项目1.1.4时间表和预算概述1.2项目管理计划的演化2参考材料3定义和缩略语4项目组织4.1外部接口4.2内部结构4.3角色和责任5管理过程计划5.1启动计划5.1.1估算计划5.1.2人员安置计划5.1.3资源获取计划5.1.4项目人员培训计划5.2工作计划5.2.1工作活动5.2.2时间表分配5.2.3资源分配5.2.4预算分配5.3控制计划5.3.1需求控制计划5.3.2时间表控制计划5.3.3预算控制计划5.3.4质量控制计划5.3.5报表计划5.3.6度量收集计划5.4风险管理计划5.5项目打结计划6技术过程计划6.1过程模型6.2方法、工具和技术6.3基础结构计划6.4产品验收计划7支持过程计划7.1配置管理计划7.2测试计划7.3归档计划7.4质量保证计划7.5评审和审计计划7.6问题解决计划7.7转包商管理计划7.8过程提升计划8附加计划图9-3IEEE项目管理计划框架9.3软件项目团队管理软件项目团队是具有共同目标、紧密协作的一个集体,包括:项目发起人、资助者、项目组(开发团队)、供应商、客户等。一般情况下,软件项目团队的特点是:临时性、团队成员的不稳定性、年轻化程度较高、是高度集中的知识型团队、成员的业绩不易量化考核。软件项目团队管理就是采用科学的方法,对项目组织结构和项目全体参与人员进行管理,在项目团队中开展一系列科学规划、开发培训、合理调配、适当激励等方面的管理工作,使项目组织各方面的主观能动性得到充分发挥,同时促进高效的团队协作,以利于实现项目的目标。9.3.1软件项目团队管理概述(1)软件项目的人力资源特征人既是最大的成本又是最重要的资源。人力成本:尽量使人力资源投
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度绿色建筑政策支持场外工程合同规范文本2篇
- 郑州西亚斯学院《别墅建筑空间设计》2023-2024学年第一学期期末试卷
- 浙江农业商贸职业学院《中级韩国语视听说》2023-2024学年第一学期期末试卷
- 2025年高科技实验室场地租赁及配套设施供应合同2篇
- 创伤科护士工作总结
- 美容美发店话务员工作总结
- 飞行器材租赁合约三篇
- 商务中心保安工作总结
- 输液外渗知识培训课件
- 网络科技行业的美工工作总结
- 简约清新大气餐饮行业企业介绍模板课件
- 氮气窒息事故案例经验分享
- 某公司年度生产经营计划书
- 厂房租赁合同标准版(通用10篇)
- 《教育心理学》教材
- 易制毒化学品安全管理制度(3篇)
- 建设单位业主方工程项目管理流程图
- 断裂力学——2Griffith理论(1)
- 风电场岗位任职资格考试题库大全-下(填空题2-2)
- 安全施工专项方案报审表
- 学习解读2022年新制定的《市场主体登记管理条例实施细则》PPT汇报演示
评论
0/150
提交评论