标准有效的项目开发流程

news2024/11/24 14:13:47

代码版本管理

在项目中,代码的版本管理非常重要。每个需求版本的代码开发在版本控制里都应该经过以下几个步骤。

  • 在master分支中拉取该需求版本的两个分支,一个feature分支,一个release分支;feature分支用于接受个人分支merge过来的代码,并用于部署dev环境。feature的代码在经过dev环境的联调后,合并到release分支,所有release分支用于接受feature分支merge过来的代码,并用于部署test环境。

    例如,需求2.0版,对应feature/olive_v2.0、release/olive_v2.0分支

  • 在 release/olive_v2.0 分支基础上建立个人分支。个人开发分支的代码一般情况下代码通过 git merge 命令合并到 feature 分支。

    例如,feature/olive_hjj_v2.0

73aad0dc780018494aed5c32e3b10bf3.png

需求流程

主要进行版本需求的功能梳理,并由产品人员输出产品原型,主要使用墨刀、axure等一些原型输出工具输出原型。主要流程如下:

  • 输出产品原型

  • 产品输出人员组织产品原型评审,主要参与人员包括:后端开发人员、前端开发人员、测试人员、UI设计人员、产品人员等 在评审过程中原型输出人员解答各参会人员提出的疑问

  • 评审后如果需要优化修改的,进行产品原型优化;并完成需求定稿,交予UI设计人员进行UI设计,输出UI图

开发流程

开发就是完成需求评审,没有任何异议后;接下来的主要工作。开发主要由前端开发人员和后端开发人员完成。它的流程主要包含以下这些:

  • 按照版本需求进行设计;主要包括表结构设计、缓存数据结构设计、功能业务流程方案设计等,并输出《xxxx设计文档》。例如:

74e3fe06000a7870c53212f3d54a0b75.png
  • 输出设计文档后,开发人员(主要是后端开发人员)组织设计文档评审。参加人员主要包括:前端开发、后端开发、架构师;如果有涉及到部署架构调整之类的设计运维人员也要组织参加;测试人员也可以参加,方便熟悉数据存储、业务分支等

  • 前端开发、后端开发进行功能开发,并完成接口联调;实现所有需求的功能

  • 开发完成后进行 测试环境 提测;提测需要发送提测邮件。邮件接受人员主要包括产品人员、测试人员、前端开发人员、后端开发人员、架构师、运维人员等。提测邮件大概内容如下:

d904fc00be31651f45c8f0b0689ce041.png
  • 在部署测试环境,测试人员表完成所有功能验证,然后产品人员验证完毕后。后端开发人员编写《生产发版文档》,并提供需要发布的成果物。主要包括:

需要提供的成果物列表

(1)数据库SQL脚本

(2)需要修改的配置文件,及需要增加、修改的配置项

(3)前端H5需要部署的zip包;APP需要发布的apk、ipa等

(4)后端需要部署jar、war等

(5)发版部署中涉及的关键步骤流程说明。例如,先改配置还是先执行SQL;是否存在需要执行接口进行数据库初始化的操作;是否需要修改Nginx等

(6)其他需要提供的成果物

以上成果物如果有发版平台直接通过发版平台提供;否则发邮箱、SVN版本等方式提供给运维人员

  • 组织人员进行《生产发版文档》评审,主要包括前端开发人员、后端开发人员、测试人员、运维人员、架构师进行评审;并确定发版时间节点

测试流程

功能开发完成后,进行功能测试是生产发版前的重要一环。在这个环节主要后测试人员主导,它的流程主要包含以下这些:

  • 测试人员全程参与版本原型的评审会议,对存在疑问的功能提出疑问;产品人员予以解答

  • 测试人员对版本需求的功能点编写测试用例,表示形式以思维导图为佳。例如:

1e2af30edc6e0fcd6c1f5f0c5bfef5a2.png
  • 输出测试用例文档后,测试人员组织测试用例评审。参加人员主要包括:前端开发、后端开发、测试人员、产品人员

  • 对版本需求功能进行测试用例测试,验证功能正常可用

  • 在测试人员对功能完成测试后,产品人员在测试环境对需求功能进行最后验收。查看功能是否服务需求设计

  • 如果项目中接入代码质量管理平台,则对代码进行静态扫描、渗透测试等。

发版流程

发版主要由运维人员来主导。它的主要工作就是把已经在测试环境验证通过的成果物部署到生产环境。它的主要流程表包括以下这些:

  • 执行变更的SQL

  • 增加需要增加的配置文件、配置项;修改需要修改的配置文件、配置项

  • 如有网络架构变更,提前开通防火墙;并验证是否开通

  • 部署后端jar、war等。如果有CI/CD平台,直接执行流水线即可

  • 部署前端H5 zip包

  • 如有Nginx配置变更,进行Nginx映射变更

  • 其他需要操作的步骤,按照后端开发人员提供的《生产发版文档》进行一一操作

  • 测试进行生产验证

9b81a4f28331ab6e41fc79d216571cd6.gif

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

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

相关文章

二叉树DFS、BFS

目录 1,DFS遍历 2,DFS遍历OJ实战 力扣 144. 二叉树的前序遍历 力扣 94. 二叉树的中序遍历 力扣 145. 二叉树的后序遍历 力扣 105. 从前序与中序遍历序列构造二叉树 力扣 106. 从中序与后序遍历序列构造二叉树 力扣 889. 根据前序和后序遍历构造二…

C++中的new、operator new与placement new

new operator 当我们使用了new关键字去创建一个对象时,你知道背后做了哪些事情吗? A* a new A;实际上这样简单的一行语句, 背后做了以下三件事情: 分配内存,如果类A重载了operator new,那么将调用A::operator new(…

TencentOS安装并运行多版本php

TencentOS版本3.1安装并运行php7,现在需要同时运行一个php8. php选择使用了php v8.0.27 采用编译安装的方式,编译命令如下: ./configure --prefix/application/php8 --with-config-file-path/application/php8/etc --with-mhash --with-o…

51单片机学习笔记-4矩阵键盘

4 矩阵键盘 [toc] 注:笔记主要参考B站江科大自化协教学视频“51单片机入门教程-2020版 程序全程纯手打 从零开始入门”。 注:工程及代码文件放在了本人的Github仓库。 4.1 矩阵键盘介绍 在键盘中按键数量较多时,为了减少I/O口的占用&#…

vuex中 this.$store.dispatch() 与 this.$store.commit()

一、理解 this.$store.dispatch 分发 actions-> 调用 mutations->改变 states 二、思考 1、为什么不直接分发 mutation mutation 有必须同步执行的限制,而 Action 不受约束,可以在 action 内部执行异步操作2、Action 通常是异步的,…

配置日志输出到指定位置的文件,单独报错error级别以上的日志,按日志类别打印日志

目录1.配置文件2.测试程序:工具:log4j的jar包、配置文件log4j.properties(文件名自定义)、eclipse或IDEA 更多参考:https://www.cnblogs.com/ITtangtang/p/3926665.html、 1.配置文件 新建一个配置文件log4j.properties(我把它放…

区块链游戏走出一地鸡毛,元宇宙3D国风链游或成最大受益者

曾推出过《Cytus》《Deemo》《聚爆》等知名游戏的雷亚,其CEO游名扬在接受采访时曾谈到,游戏产业是文化产业加上科技产业的组合体,这两者是组成游戏产业的主要部分。看游戏的趋势,就要针对文化和科技的趋势上来看。 这话没错。 20…

flutter StreamController,ValueListenableBuilder,NotificationListener

FutureBuilder &#xff08;异步数据更新&#xff09; StreamBuilder &#xff08;异步数据更新&#xff09; 构造函数 特点 接收多个异步操作的结果class StreamBuilder<T> extends StreamBuilderBase<T, AsyncSnapshot<T>>{}单订阅&#xff1a;StreamCo…

在Linux中进行Hbase搭建

在公网IP为x.x.x.x、y.y.y.y和z.z.z.z并装有Centos8的服务器上进行hadoop集群搭建、zookeeper集群搭建和hbase搭建&#xff0c;都安装hadoop-3.1.3、server-jre-8u202-linux-x64、apache-zookeeper-3.6.4-bin和hbase-2.5.0-bin。 环境准备&#xff08;三台服务器都一样&#x…

基于javaweb宠物领养平台管理系统设计和实现

基于javaweb宠物领养平台管理系统设计和实现 博主介绍&#xff1a;5年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 Java毕设项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源码联系方…

C++基础——C++ 判断

C基础——C 判断C 判断判断语句C if 语句语法流程图? : 运算符C 判断 判断结构要求程序员指定一个或多个要评估或测试的条件&#xff0c;以及条件为真时要执行的语句&#xff08;必需的&#xff09;和条件为假时要执行的语句&#xff08;可选的&#xff09;。 下面是大多数编…

DAMA数据管理知识体系指南之数据管理概述

第2章 数据管理 2.1 引言 2.2 使命和目标 使命 在信息的可用性、安全性和质量方面&#xff0c;满足并超越企业中所有利益相关者的信息要求。 战略目标 &#xff08;1&#xff09;理解企业和所有利益相关者的信息需求。 &#xff08;2&#xff09;获取、存储、保护和确保数据资…

堆的结构及函数接口、堆排序,TopK

本篇内容涉及到二叉树的概念及性质&#xff0c;可参考文章 树和二叉树的概念及性质 文章目录一、堆的概念二、堆的存储结构三、堆的函数接口1. 初始化及销毁2. 打印函数3. 堆的插入4. 堆的删除5. 取堆顶、判空、数据个数四、建堆算法和时间复杂度1. 向上调整建堆2. 向下调整建堆…

CTFshow--web--红包题第二弹

查看源代码&#xff0c;按注释提示&#xff0c;构造参数试试?cmdaa<?php #error_reporting(0); ?> <html lang"zh-CN"><head><meta http-equiv"Content-Type" content"text/html; charsetUTF-8" /><meta name&quo…

MATLAB绘制爱心曲线并导出

MATLAB绘制爱心曲线并导出 爱心曲线的表达式&#xff1a; f(x)x2/3e3(π−x2)1/2sin(aπx)f(x)x^{2/3}\frac e 3(\pi-x^2)^{1/2}sin(a\pi x) f(x)x2/33e​(π−x2)1/2sin(aπx) f (x,a)x.^2.^(1/3)exp(1)/3*(pi-x.^2).^(1/2).*sin(a*pi*x); h figure(color,[1 1 1]); set(g…

应用系统与钉钉集成案例及操作步骤

1、准备钉钉应用 1.1、注册钉钉账号 作为钉钉的企业管理员&#xff0c;首先登录钉钉官网&#xff0c;注册一个钉钉账号。 如果已经有账号&#xff0c;则直接使用即可。 钉钉官网&#xff1a;https://www.dingtalk.com/ 1.2、开通企业团队 企业管理员使用账号登录钉钉。 如…

如何限制docker容器使用内存大小

本文介绍如何通过docker运行参数配置限制docker容器可以使用的内存上限。docker容器默认可以使用全部宿主机的所有内存和 swap 分区&#xff0c;比如宿主机的内存是32G&#xff0c;则运行一个docker容器最多可以分配到32G内存&#xff0c;如果启用了多个docker容器&#xff0c;…

CSS实现文本显示两行

效果图 text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: 2;-webkit-box-orient: vertical;display: -moz-box;-moz-line-clamp: 2;-moz-box-orient: vertical;overflow-wrap: break-word;word-break: break-all;white-space: normal;overflow: hidden;text-…

SAP ADM100-2.2 SAP系统开启过程中的配置文件

SAP系统的每个实例需要的数据都在文件系统中,包括所有实例都需要访问的全局数据(Globally)和个别实例需要访问的数据。在文件系统汇总,实例需要的数据被包含在usr/sap目录,在这里被进一步组织到子目录。 【注意】:业务数据和相关数据被存储在数据库中,数据库根据不同的制…

【GD32F427开发板试用】三、USB转CAN功能开发与试用总结

本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动&#xff0c;更多开发板试用活动请关注极术社区网站。作者&#xff1a;chenjie 【GD32F427开发板试用】一、环境搭建与freertos移植 【GD32F427开发板试用】二、USB库移植与双USB CDC-ACM功能开发 【GD32F427开发板…