实施方法论

软件实施方法论(通用)

软件项目实施交付模型
很多领域流传着'别人家'的传说:别人家的孩子学习成绩好才艺多还长得帅,别人家的客户钱多人傻速来,别人家的公司不加班产品做得好工资还发的倍儿高。这一切事情实际上都有'常量'和'变量',比如你的竞争对手突然一夜之间,转型去做房地产了这种变量,可遇不可求而且不受自身控制。一家公司无论是经营还是优化经营模式,都是从控制'常量'开始。在企业软件部署实施中,这种常量(稳定的事情,或者变动但是可控制,可预测的)的控制,就是具体的实施模型和方法论。
 

没有模型



时间:未知
资源:未知
风险:未知
产出:未知
 
如果在使用量上来讲,软件部署使用中最多用到的应该是'没有模型'。也就是用户/软件设计者想到了什么,或者一时心血来潮有了新的创意,就马上告诉软件部署人员/开发人员自己的想法。然后一边想,一边做。做了觉得不满意,又开始想新的想法;亦或者是发现之前想打的疏漏,又马上想新的点子去补救。虽说大道至简,但是往往需要一定的功力才能至简的了。往往按这种情况发展下去,需求方会觉得焦头烂额,开发方会觉得叫苦不迭,最后别别扭扭的产出个四不像,或者是什么都没有产出,甚至是大打出手(咳咳),所以这种粗放式的所向即所得模式,个人可以试试,团队协作的话效果往往不会很好。
 
 
瀑布模型



时间:一般
资源:一般
风险:一般
产出:一般
 
1970年就诞生的模型,对于软件部署中的情境做了最理想的串行假设:我们首先选好什么软件/用什么样的方式来开发,然后呢,跟用户谈一下他们的所有需求,分析一下,写成文档,然后就可以按文档开始做了噢。做完了交付测试一下。好吧?没问题了吧?那我们开始正式使用了,顺便再维护一下。瀑布模型逻辑简单,结构清晰,就是一个字:稳。一件事情完成才能做另一件,而且必须有文档记录和验证。但是在2017年的今天,稳已经不是主旋律了,快才是。工程师不再愿意写长长的流水账设计文档,公司往往需要需求的功能可以马上实现,用户希望他们的想法往往可以马上看到。瀑布的水还在半空中,上游下游就可能已经面目全非。时代在发展,理所当然也会慢慢变成匪夷所思。
 
喷泉模型



时间:短
资源:多
风险:大
产出:良
相比于串行的瀑布模型,喷泉模型对软件部署做了并行的假设:小张你们BI哪块程序出来了吧,赶快安排用户做单元测试。小王上次财务部谈了需求功能设计出来了没有,没有赶快出。小K人力那边测试完了觉得薪酬哪块可以再细化一下具体你找他们谈。团队面对的是一个个具体的功能块,每块都有快速迭代,又没有明显边界的'子项目',像一个喷泉一样源源不断,周而复始,各自独立而又统一。这种方式灵活度满分,可以高效快速的拥有可见的成果。但是并行意味着更多的人员需求,同时灵活也意味着更难管理。想要让喷泉源源不断而又一致稳定,管控水平是一个核心。
 
快速原型模型



时间:中等偏长
资源:多
风险:一般
产出:优
 
快速原型的核心就在于原型。围绕着原型,伴随着原型从0%到100%的完成度,用户和程序设计人员满满一起认识到需求到底是什么,我们怎么样的方式来实现这个需求是最优的,未来可能的发展方向又是什么。快速原型的方式在应对模糊需求的时候有奇效。老板说,我要一个CRM,你去设计一下。?(黑人问号)。用快速原型的方式,做几个简单的区块,甚至是用Axure仅仅停留在设计阶段的展示,都能对模糊的需求有一个快速的,通过前20%对后80%工作的定位。但是原型的品控,方向的把控也是这个模型的核心,是区别与原型一步步迭代和反反复复做一件同样的事情和核心点。抓住核心,看到本质,是做快速原型而不是无头苍蝇的基本要素。
 
 
螺旋模型



时间:很长
资源:多
风险:低
产出:一般
 
前人栽树后人乘凉,螺旋模型是瀑布模型和快速原型模型集合风险控制的新理论。螺旋模型从风控角度出发,以瀑布模型为框架来实现产品的快速原型化。一小段一小段的来构建系统,并且在每个'段'都进行具体的风险识别,控制&分析工作。从而使工作进度像螺旋一样一层一层,一级一级的来到核心。螺旋模型按段来分项目,并且每段都有严格的风控,一方面产出更直观,另一方面这种每个阶段的回顾和评估,也能保证方向不会南辕北辙。由于这方面的特性,因此一般是高风险,强风控的项目会用到螺旋模型,使用场景比较局限。而且风险识别能力是一门独到的学问,对人员的素质要求也不一般。
 

软件项目实施交付流程:


实施方法论的价值:

  • 快速实施:更有效的实施交付框架,指导顾问快速完成交付工作。
  • 降低风险:利用提炼出的经验与标准模板,来降低项目风险。
  • 节约成本:聚焦关键交付工作,减少无效返工的投入。


下面分别阐述实施方法论每个阶段具体要做的事,目的,价值或相关建议,供参考。
一、项目启动:

项目实施为什么要做项目启动会?
按照PMBOK这本书对项目的定义:"项目是为创造独特的产品,服务或成果而进行的临时性工作。"我们尝试简单解读一下,项目有2个特点,临时性和独特性。临时性是指的是有明确的开始时间和结束时间,不一定是项目的时间周期短。独特性是指每个项目都不尽完全相同,都有每个项目的独特之处,比如交付的产品,服务,成果,程序版本,团队成员,设备,环境因素等存在一定的独特性,每个项目都不完全相同。正是项目具有临时性和独特性,所以项目有风险。

一般来说,我们所说项目实施是指乙方给甲方交付某个项目或产品系统或履行某项服务等。假设你是项目交付的乙方,你应该知道甲方即将要新上一个系统,它很可能涉及到甲方的核心业务流程和数据。所以在实施进场后,一般是需要经历一个"漫长"(视项目大小而定)的需求调研过程,需要和甲方多个部门的关键需求方进行系统需求调研,流程沟通和流程梳理等,这些过程不仅在短期内将改变甲方员工的工作方式,增加了他们的工作量,甚至在调研过程中甲方的组织架构调整,原本需求方的负责人发生变化,需求决策人也可能跟着发生变化,权责利再分配等等问题,都会导致你按时成功交付项目的阻力重重,处处都是风险。
启动会要达到什么目的?

  • 认识客户方高层
  • 吸引高层注意,提升关注度,重视项目进展。
  • 分析和判断客户方对项目具有决策力的关键人物
  • 了解客户关键决策人对项目的期望
  • 要求客户明确参与项目的关键角色以及职责
  • 了解和认识客户方接口人对项目的影响力
  • 识别客户方的项目支持者与反对者
  • 明确项目范围


启动会要提前准备哪些内容?
根据个人准备启动会的经验,已经把启动会的会前准备和启动会PPT等事项,主要内容,输出等做了详细的整理,以下供参考:


二、需求调研
需求调研是针对SOW里面约定的需求范围进行逐一沟通与澄清,记录调研访谈的内容,为后续的需求蓝图设计方案打好基础。
调研计划:
在入场前你要规划好一份详细的调研日程计划,然后和甲方项目经理并协调人按计划参与需求调研。
调研问卷:
在实际调研前,请提前准备要调研的问卷,并提前下发给客户方项目经理和相关需求方,让他们提前准备和梳理你要开始调研的需求或问题。
调研内容:
业务流程,数据流向,业务表单(实体表单),管理诉求(权限/报表/监控等)
调研目的:
进一步细化了解SOW中的需求内容,并为蓝图设计提供设计依据,讲的清楚说的明白。
需求调研CheckList:
根据个人准备需求调研的经历,已经把需求调研的相关事项,主要内容,输出的交付物等做了详细的整理,以下供参考:


三 蓝图设计
蓝图设计是根据前期的需求调研,SOW等内容进行综合需求分析,在理解了客户方系统业务需求,管理诉求之后,输出的一份系统建设方案的汇报材料。主要内容涵盖项目的背景,本期目标,长远目标,前期的工作成果,设计方案展示等内容。蓝图汇报之后,双方需要尽快进行蓝图确认,以便基于蓝图方案进行下一步配置开发和系统落地。
蓝图设计的目的:
主要阐述下一阶段将参照蓝图方案中的《业务流程图》,《系统流程图》,《系统集成设计方案》等进行系统配置开发,将宏观的系统规划切实落地到实际系统建设的中。
蓝图设计的价值:
给客户方的决策层和管理层重申项目目标,项目范围,展示蓝图方案等,再次塑项目价值,调动高层信心,持续甚至更强有力的提供各类资源和支持,保障项目顺利推进下去。
蓝图设计方案汇报PPT应包含的内容CheckList:


四 系统配置开发
配置开发我这里合二为一,它实际应该为系统配置和系统开发两个环节。如果是系统标准功能实施,一般只需要根据需求方案进行系统配置即可。如果是含有系统集成等相关非标功能的开发等,需要进行配置及开发两个环节。
系统配置开发清单:


五 系统测试
一般系统测试分为单元集成测试和用户UAT测试,单元测试主要是项目涉及的双方项目组或多方项目成员内部做集成测试,保证集成的功能,流程 ,数据等测试正常,测试点主要偏重系统接口,系统性能,数据交互等是否符合标准。用户UAT测试,主要是客户方关键用户参与使用测试和验收测试,测试点主要偏重系统业务流程,各角色操作人员的操作是否便利,管理人员是否能监控和查看报表等,偏重业务功能和流程等。如果要求严格的甲方,还会强制要求进行渗透测试等进行系统安全性等考量,作为乙方应当配合甲方完成安全性等其他的相关测试。
相关建议:
在实际项目实施过程中,根据项目大小,实施的范围,功能标准与非标,安全性等实际情况进行适当的裁剪。

如果是简单的标准化功能实施配置,只需要进行简单的系统功能测试,就立即进入UAT测试阶段。

如果是较大的集成项目,且对测试要求比较严格的,就按照标准的测试要求严格执行保障测试结果符合要求。

另外当甲方测试反馈了很多问题,要求你需要在上线前进行整改完毕,遇到这种情况要妥善处理,不要完全听从甲方的要求,要合理和甲方谈判,对测试问题分好优先级,哪些问题上线前必须解决,哪些问题可以上线后陆续解决,哪些问题甚至可以上线后不解决等等。

总之,既要要保证测试充分,暴露所有系统问题,也要保证系统主流程能跑通,不影响核心业务,要及时推进按时交付上线,然后迅速迭代。

千万不要想着解决所有问题在推上线,千万不要这样追求完美。只有成功的项目,没有完美的项目。

六 切换准备:
系统能否如期上线,就要看切换准备这个阶段各项工作是否做得到位。切换准备这个阶段需要做历史数据的正式导入,数据库切换,生产系统切换技术方案和评估,切换失败的回滚机制等。
相关建议如下:
1、数据备份:
在系统升级切换前,应联系专业运维人员进行系统程序,数据库等相关数据备份,以免系统升级异常导致故障且不能恢复数据的问题。
2、历史数据导入的问题:
一般大一点的客户都会使用过其他系统,大部分时候都是存在历史数据,且要求导入系统。在系统建设早期,就应当识别客户的导入历史数据的诉求,且提前提供数据模版让客户提前整理数据。从一般项目实践经验来看,大部分因数据导入影响系统切换的都是没有提前安排进行数据清洗和结构化处理数据导致。在临近上线前一两天,以为导数据很快,可在实际导入数据过程中发现很多数据本身,或其他技术问题,或工作量的问题,导致通宵导入数据且上线延期的案例比比皆是。
3、切换方案准备:
提前准备好系统切换方案,切换步骤,切换时间 ,切换故障紧急联系人,应急问题处理机制,切换失败回滚机制等等,准备好召集双方的项目团队成员进行评审,并切换方案进行修正,达成一致后,邮件抄送所有的项目相关方,让他们知悉。
4、系统培训:
在上线前,要组织对关键用户进行系统培训,然后协助关键相关方对所有系统用户做好系统培训,并收集用户的使用反馈,及时对系统进行优化。
七 系统上线:
按照评审通过的项目上线切换方案执行系统切换,切换后密切关注系统运行情况和用户反馈,积极的处理系统问题,保障系统平稳运行,至少不出现系统奔溃,主流程阻塞等致命问题。
八 验收与持续支持:
按合同或协议约定,一般系统上线后一段时间后,需要执行验收流程,对项目进行验收。作为乙方,要在上线后尽快获得甲方的认可和系统的正式验收,越早验收越好。系统验收后,意味着项目实施进行项目结束阶段。项目组需要尽快与售后的部门进行内部项目交接,进入客户项目的售后运维阶段,由售后部门进行客户后续的项目支持,项目组成员逐步撤出。在内部交接的过程中,一定要注意交付物文件完整,所有实施过程的相关项目文件,如调研纪要,蓝图设计方案,需求设计说明书,流程图,接口文档,业务开发代码等全部交接好,一是便于售后技术支持人员能支持服务客户,二是,方便做好项目文件归档及交付物文档在验收环节发送给客户。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

iptables的一次修复日志

iptables的一次修复日志 搭建配置wireguard后,使用内网连接设备十分方便,我采用的是星型连接,即每个节点都连接到中心节点,但是突然发生了重启wg后中心节点不转发流量的问题,即每个接入的节点只能与中心节点连接&…

请收好|实验室仪器管理知识大全

实验室的仪器设备是直接用于提供检测结果或辅助检测进行的,是实验室的重要资产,也是重要的检测工具。对检测结果的准确性和可靠性起到至关重要的作用。如何保持仪器设备的有效性和可靠性,使仪器设备处于完好的状态,在产品质量检测…

使用Dockerfile构建hexo博客镜像,并部署

基于centos7.9父镜像构建hexo:1.0镜像&#xff1a; cat << eof > Dockerfile # 根镜像 FROM centos:7.9.2009 MAINTAINER qv123<qv1095322098163.com> # 设置工作目录 WORKDIR /usr/src/app # 暴露端口号 EXPOSE 4000 # 作者注释 MAINTAINER qv123<qv1095322…

“绵柔的,好喝的”海之蓝畅销20年的经典秘诀:做大众喜爱的好酒

执笔 | 尼 奥 编辑 | 萧 萧 在中国白酒历史长河中&#xff0c;有的品牌如大浪淘沙而灰飞烟灭&#xff0c;也有的白酒品牌因为不断创新而经久不衰。我们时常在思考一个产业命题&#xff1a;白酒品牌常青的秘诀到底是什么&#xff1f; 经过20多年的产业发展&#xff0c;中国…

壹基金宣传进瑞金河背街社区 安全家园项目防灾减灾深入人心

11月16日下午&#xff0c;瑞金赋能公益、蓝天救援队等联合象湖镇河背街社区开展家庭安全计划社区活动包挑战赛活动暨壹基金安全家园项目防灾减灾宣传社区行活动。活动得到了救助儿童会北京代表处、壹基金、艾特公益、益心益意公益的指导&#xff0c;得到了阿里巴巴公益平台广大…

【数据结构】链表的八种形态

&#x1f984;个人主页:修修修也 &#x1f38f;所属专栏:数据结构 ⚙️操作环境:Visual Studio 2022 目录 链表的三大"性状" 一.带头链表和不带头链表 头指针与头结点的异同 头指针 头结点 二.循环链表和非循环链表 三.双向链表和单向链表 链表的八大形态 结语…

键盘快捷键工具Keyboard Maestro mac中文版介绍

Keyboard Maestro mac是一款键盘快捷键工具&#xff0c;它可以帮助用户通过自定义快捷键来快速完成各种操作&#xff0c;提高工作效率。Keyboard Maestro支持多种快捷键组合&#xff0c;包括单键、双键、三键、四键组合等&#xff0c;用户可以根据自己的习惯进行设置。此外&…

测试工程师一定要会的Jmeter_性能测试教程:性能测试脚本的优化

性能测试脚本的优化 以PHP论坛为例&#xff1a;http://47.107.178.45/phpwind/ 根据上一篇的性能测试(3&#xff09;的脚本进行优化&#xff1b;见下图&#xff1a; 如上图中&#xff0c;把发帖和回帖的事务添加到随机控制器中&#xff0c;登录操作添加到仅一次控制器中&…

修改el-radio-group样式,自定义单选组件

修改el-radio-group样式,自定义单选组件 自定义组件 MyRadioGroup.vue <template><div class"btnsBox"><el-radio-group v-model"activeIndex" change"handleClick"><el-radio-buttonv-for"(item, index) in list&qu…

万户OA upload任意文件上传漏洞复现

0x01 产品简介 万户OA ezoffice是万户网络协同办公产品多年来一直将主要精力致力于中高端市场的一款OA协同办公软件产品&#xff0c;统一的基础管理平台&#xff0c;实现用户数据统一管理、权限统一分配、身份统一认证。统一规划门户网站群和协同办公平台&#xff0c;将外网信息…

vite vue3配置axios

准备 参考 安装axios yarn add axiossrc下新建request文件夹&#xff0c;该文件下新建index.ts import axios from axios; import { ElMessage } from element-plus;// const errorCodeType function (code: number): string { // let errMessage: string 未知错误; // …

SqlServer_idea连接问题

问题描述&#xff1a; sqlServer安装之后可以使用navicat进行连接idea使用账户密码进行登录连接失败 问题解决&#xff1a; 先使用sqlServer管理工具进行登录 使用window认证连接修改账户密码 启用该登录名 这时idea还是无法连接&#xff0c;还需要如下配置 打开sqlserve…

SVG直线 <line>与折线 <polyline>代码示例

本专栏是汇集了一些HTML常常被遗忘的知识&#xff0c;这里算是温故而知新&#xff0c;往往这些零碎的知识点&#xff0c;在你开发中能起到炸惊效果。我们每个人都没有过目不忘&#xff0c;过久不忘的本事&#xff0c;就让这一点点知识慢慢渗透你的脑海。 本专栏的风格是力求简洁…

LR学习笔记——图片管理分类

文章目录 图片标记图片筛选图片分类 图片标记 可以看到上面的第二排&#xff0c;每个图片都有不同的标记&#xff0c;前5张用星级进行标记&#xff0c;后三张用颜色进行标记 可以直接在图片下方点击几星级即可进行标记&#xff0c;也可以使用键盘上的数字键1-5进行打星 相对的&…

AnyTXT Searcher:本地文件内容搜索神器如何搭建与远程访问

文章目录 前言1. AnyTXT Searcher1.1 下载安装AnyTXT Searcher 2. 下载安装注册cpolar3. AnyTXT Searcher设置和操作3.1 AnyTXT结合cpolar—公网访问搜索神器3.2 公网访问测试 4. 固定连接公网地址 前言 你是否遇到过这种情况&#xff0c;异地办公或者不在公司&#xff0c;想找…

洛谷 P4568 [JLOI2011] 飞行路线 pytho解析

P4568 [JLOI2011] 飞行路线 pytho解析 时间&#xff1a;2023.11.20 题目地址&#xff1a;[JLOI2011] 飞行路线 题目分析 对于这个题呢就是最短路的问题了。那就可以用Dijkstra 算法&#xff0c;唯一不同的地方就是有免费的机票次数&#xff0c;那我们就先不考虑这个&#xf…

Linux vi和vim编辑器、快捷键的使用

Linux vi和vim编辑器、快捷键的使用 vi和vim的三种模式使用vim编写Hello.java文件vim快捷键和命令 在Linux下一般使用vi编辑器来编辑文件&#xff0c;vim是它的增强版。vim用于在远程环境下用命令形式对文本进行在线编辑&#xff0c;既可以查看文件也可以编辑文件。 vi是Linux系…

LINUX入门篇【7】--git提交指令以及代码调试工具gdb

前言&#xff1a; 我们今天来介绍一下我们工具篇的最后两个工具&#xff0c;即git提交指令以及代码调试工具gdb,再结合前面的知识点&#xff0c;我们就可以基本完成我们VS上的基本的功能&#xff1a;编写&#xff0c;调试&#xff0c;编译&#xff0c;执行程序的这些过程。 1…

leetcode:反转链表

题目描述 题目链接&#xff1a;206. 反转链表 - 力扣&#xff08;LeetCode&#xff09; 分析题目 思路一 我们可以设计算法让整个链表掉头 定义三个代码n1,n2,n3 n1指向NULL&#xff0c;n2指向head&#xff0c;n3指向第二个结点 当n2不为NULL的时候&#xff0c;让n2->ne…

ResizeObserver观察元素宽度的变化

ResizeObserver观察元素宽度的变化 ResizeObserver观察元素宽度的变化 ResizeObserver观察元素宽度的变化 ResizeObserver 构造函数创建一个新的 ResizeObserver 对象&#xff0c;它可以用于监听 Element 内容盒或边框盒或者 SVGElement 边界尺寸的大小。查看详细说明 案例 &l…