跨部门算法迭代需求,从提出到上线的全流程实践

news2025/5/24 22:13:45

文章目录

  • 引言
  • 需求评审
  • 技术方案评审
  • 模块开发
  • 系统联调
  • QA测试
  • 产品验收
  • 经验教训

引言

最近工作中有一个算法迭代的需求,我在其中作为技术侧负责人(技术主R)推动需求完成上线。

需求涉及多个部门,前后耗时接近1个月。

我第一次在这么复杂的需求中做技术主R,深入参与了需求从提出到上线的全流程,中间踩了不少坑,特此把整个过程记录下来,供大家参考。

我按照时间顺序,将全过程分成5个阶段:产品需求评审->技术方案评审->模块开发->系统联调->产品验收,接下来也会按照这个顺序依次描述。

正文见下。

需求评审

为了描述清楚此次需求,我画了个简易的系统数据交互图,步骤大概为:C向D触发一次计算请求,D拿到必要的参数后,将其传给算法,算法计算完成后将结果返回给D,D将结果包装后再返回给C;C将结果做必要的处理后,继续推送给Z,Z处理后再依次传给K、J和G等下游。

系统现状是:整个系统是已有的,但算法侧在计算时只有A类数据。此次核心需求是:算法侧需要增加X和L类数据,以提升最终的核心指标。

从系统能力上看,在拿到更多数据后,算法能分析得到更多内容。从系统变更上看,算法需要新增决策的逻辑,其他模块则需要增加接口字段并对新数据进行包装和处理。

初步盘点下来,此次主要的改动是算法侧,因此作为算法迭代负责人的我,便成了本次需求的技术主R。

技术方案评审

我被确定为技术主R后,产品便催我去约其他模块负责人的时间,早点组织技术方案的评审。

我找了一个大家都空闲的时间段,确定了评审时间。在实际评审时发现,只有我写了比较完善的技术方案,K写了大概思路,其他人什么都没有。当时感觉,大部分模块确实只有一些接口上的变动,好像没啥需要写的,所以也没在意。

会议上遗留的重要TODO是:(1)完善整体技术方案;(2)确定各模块工时、预期上线时间和具体的排期。

技术方案在会前并没有写,实际上是评审后补充的,主要包含4项内容:

(1)需求背景和目标,此处直接复制了需求文档中的内容;

(2)总体设计,此处复制此前系统开发时绘制的系统交互流程图;

(3)详细设计,按模块分别@了各负责人,并告知将各自的技术方案添加至此;

(4)工时预估和排期,评审会上做了初步沟通,结束后又逐一确认,然后得到了如下的排期。

模块开发

进入模块开发阶段后,我和D确认了输入和输出接口的字段后,就埋头撰写算法代码了。算法主要关注的事项有两个:(1)输出结果准确,这是基本要求,自不必多说;(2)能兼容线上已有版本,确保上线后不影响线上功能。

在完成代码开发、结果自测和代码评审之后,我就坐等联调了。

系统联调

由于所有联调都依赖D能正确从算法模块拿到数据,所以需要先专注于算法和D的联调。刚开始联调过程并不顺利,到了联调的第二天下午,才基本没有问题。后来我反思了一下原因,主要是因为算法需要的输入X在联调前只有大概字段,并没有提供具体实例,导致在联调时,算法耗费了大量时间在实例数据的处理上。

因为联调一共只有两天,到了联调的第二天下午,产品开始在群中询问联调进度。然后才发现,只有D和算法在联调,其他内容都没开始。所以其他模块间的联调也要快速动起来了。

很快,C出现了大问题:算法返回更多数据后,C只有新数据的接收功能,并没有继续开发针对新数据的处理功能,所以新数据实际上并不可用。

紧急沟通后的结论是:C需要2天重新思考技术方案和代码开发,然后再用2天做系统联调。

没办法,我只能在群中同步产品和老板们,项目上线日期需要延期4天。

为了提升第二次系统联调的效率,经领导的提醒,我梳理了联调的顺序,并提醒大家完成后依次在群中确认。

最终,第二次联调耗时2.5天。

QA测试

技术方案评审的时候,和QA约定的是,由于其他模块改动量较少,所以只对算法(+D)模块做测试,其他模块的测试由各自负责人自行完成。

因C导致的延期,并不影响QA测试算法模块,所以QA测试无需延期,可以按期开始。

算法测试的全流程为:(1)QA和算法、产品确认需要测试的功能点;(2)QA构造测试数据,并逐一测试算法结果是否符合预期;(3)反馈测试结果。

最终,QA测试很顺利,几乎不需要花时间再对算法代码做优化。

产品验收

产品验收分为测试环境验收和线上环境验收。

验收用例范围由产品确定,并由算法、D和C构造所需的必要输入。

本以为会和联调测试一模一样,但实际上产品验收时考虑的更多——还需要确认是否会影响到其他需求,以及是否会被其他需求影响。

验收过程也是比较顺利的,只有J模块有点小问题。

最终,测试环境验收共耗时2.5天,系统正式上线后,线上环境验收耗时0.5天。

经验教训

如果是有经验的技术主R,可能已经发现了很多我做的不好的地方。
这里我反思总结如下:

(1)技术方案应该在评审前就有个初版,各模块需要完成的功能应该和相关负责人达成一致,模块间的接口参数应该定义清楚。

(2)算法需要的数据样例,应该要求D至少在模块开发的中期就提供出来。

(3)系统联调时,需要提前确定联调的顺序和步骤,并告知相关方。

(4)在各个阶段都要及时跟进各模块进度,感知可能存在的风险,并寻找解决方案。

(5)排期时,不要过度压缩时间,还要有预留时间。

虽然此次经历并不是完美,但依然收获颇多,总结如下:

(1)更细致地了解整个系统。平时的工作基本仅限于算法和D,做了主R后,会倒逼自己了解清楚C、Z等后续所有模块。

(2)深度参与了一个需求从提出到上线的所有过程,极大拓宽了自己的认知,是一次很有意思的的体验。

(3)相比新系统开发的需求,算法同学更适合在系统迭代的需求中做主R。

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

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

相关文章

transdata笔记:手机数据处理

1 mobile_stay_duration 每个停留点白天和夜间的持续时间 transbigdata.mobile_stay_duration(staydata, col[stime, etime], start_hour8, end_hour20) 1.1 主要参数 staydata停留数据(每一行是一条数据)col 列名,顺序为[‘starttime’,…

Istio

1、Istio介绍 Istio 是由 Google、IBM 和 Lyft 开源的微服务管理、保护和监控框架。 官网:https://istio.io/latest/zh/ 官方文档:https://istio.io/docs/ 中文官方文档:https://istio.io/zh/docs Github地址:https://github.com…

System.Data.SqlClient.SqlException:“在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误

目录 背景: 过程: SQL Express的认识: 背景: 正在运行程序的时候,我遇到一个错误提示,错误信息如下,当我将错误信息仔细阅读了一番,信息提示的很明显,错误出现的来源就是连接数据库代码这块string connStr "s…

编写servlet

编写servlet 上述代码中的HTML页面将雇员ID发送给servlet。要创建servlet读取客户机发送的雇员ID并检索雇员的详细信息,需要执行以下步骤: 在“项目”选项卡中右击“Employee”节点,然后选择“新建”→Servlet。将显示“新建Servlet”对话框。在“类名”文本框中输入Employ…

【Kaggle】泰坦尼克号生存预测 Titanic

文章目录 前言案例背景数据集介绍加载数据集探索性数据分析(EDA)可视化特征和目标值之间关系缺失值分析 数据预处理数据清洗缺失值处理去除噪声并且规范化文本内容 数据转换 数据划分建模逻辑回归模型决策分类树模型随机森林模型梯度提升树模型 预测LR 完…

C++笔记之bool类型的隐式转换现象与应用

C++笔记之bool类型的隐式转换现象与应用 —— 《C++ Primer Plus》 文章目录 C++笔记之bool类型的隐式转换现象与应用1.C++中,有几种类型和表达式可以隐式转换为bool类型2.使用explicit关键字来声明显示转换运算符,这样只有在使用static_cast<bool>时才能将对象转换为…

SpringCloud之OpenFeign的学习、快速上手

1、什么是OpenFeign OpenFeign简化了Http的开发。在RestTemplate的基础上做了封装&#xff0c;在微服务中的服务调用发送网络请求起到了重要的作用&#xff0c;简化了开发&#xff0c;可以让我们跟写接口一样调其他服务。 并且OpenFeign内置了Ribbon实现负载均衡。 官方文档…

GEE:最小距离分类器(minimumDistance)分类教程(样本制作、特征添加、训练、精度、最优参数、统计面积)

作者:CSDN @ _养乐多_ 本文将介绍在Google Earth Engine (GEE)平台上进行最小距离分类(minimumDistance)的方法和代码,其中包括制作样本点教程(本地、在线和本地在线混合制作样本点,合并样本点等),加入特征变量(各种指数、纹理特征、时间序列特征、物候特征等),运行…

中仕教育:国考调剂和补录的区别是什么?

国考笔试成绩和进面名单公布之后&#xff0c;考生们就需要关注调剂和补录了&#xff0c;针对二者之间的区别很多考生不太了解&#xff0c;本文为大家解答一下关于国考调剂和补录的区别。 1.补录 补录是在公式环节之后进行的&#xff0c;主要原因是经过面试、体检和考察&#…

高速CAN总线 m 个节点竞争总线时 电压分析(共 n 个节点)

电路的串并联关系参考<<高速CAN总线 A C节点竞争总线时 电压分析(共ABC三个节点)>> M个节点同时发送显性电平 如下图: 由上图可以看出,上下并联的M组30Ω的等效电阻R0 &#xff08;30/m&#xff09; Ω 中间并联的电阻R1 由公式&#xff1a; 1/R1 1/120 1/120…

LV.19 D1 C++简介 学习笔记

一、C概述 1.1 C的前世今生 C是一种被广泛使用的计算机程序设计语言。它是一种通用程序设计语言&#xff0c;支持多重编程范式&#xff0c;例如过程化程序设计、面向对象程序设计、泛型程序设计和函数式程序设计等。 C的发展&#xff1a; 1.2 C的主要应用领域 C是一门运用很广…

海外抖音TikTok、正在内测 AI 生成歌曲功能,依靠大语言模型 Bloom 进行文本生成歌曲

近日&#xff0c;据外媒The Verge报道&#xff0c;TikTok正在测试一项新功能&#xff0c;利用大语言模型Bloom的AI能力&#xff0c;允许用户上传歌词文本&#xff0c;并使用AI为其添加声音。这一创新旨在为用户提供更多创作音乐的工具和选项。 Bloom 是由AI初创公司Hugging Fac…

AtCoder Regular Contest 170(A~B)

A - Yet Another AB Problem 给你两个字符串S和T&#xff0c;你可以对S执行操作&#xff0c;选择两个字符&#xff0c;将前面的改为A&#xff0c;后面的改为B&#xff0c;最少操作几次可以把S改成T。如果改不成就输出-1。 从左往右一个一个改过去&#xff0c;分类讨论&#x…

html 会跳舞的时间动画特效

下面是是代码&#xff1a; <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns"http://www.w3.org/1999/xhtml"> <head> <meta h…

php基础学习之代码框架

一&#xff0c;标记 脚本标记&#xff08;已弃用&#xff09;&#xff1a;<script language"php"> php代码 </script> 标准标记&#xff1a;<?php php代码 ?> 二&#xff0c;基础输出语句 不是函数&#xff0c;…

基于yolov5-master和pyqt5的森林火灾监测软件

文章目录 项目背景效果演示一、实现思路① 算法原理② 程序流程图 二、系统设计与实现三、模型评估与优化 项目背景 火灾作为威胁人类生命生产安全的隐患之一&#xff0c;一直是人们关注的重点。传统的火灾监测装置根据温度来检测火灾&#xff0c;不仅灵敏度差&#xff0c;而且…

信息安全的脆弱性及常见安全攻击

目录 信息安全概述信息安全现状及挑战传统安全防护逐步失效 安全风险能见度不足看不清资产看不见新型威胁看不见内网潜藏风险 常见的网络安全术语信息安全的脆弱性及常见安全攻击网络环境的开放性协议栈的脆弱性及常见攻击常见安全风险 协议栈自身的脆弱性网络的基本攻击模式 链…

Fiddler替换原网页元素

我将此代码替换为我的图片时&#xff0c;再进行加载的页面&#xff0c;图片将改变。 此效果主要用于当某些网站使用js脚本注入&#xff0c;来禁止F12访问时&#xff0c;可以将他的js文件替换为空。 例&#xff1a;<script disable-devtool-auto srcmhttps://cdn.jsdelivr.…

磁盘的分区与文件系统的认识

磁盘的认识 了解磁盘的结构&#xff1a; 1、盘片 硬盘首先会有多个盘片构成&#xff0c;类似很多个独立的光盘合并在一起&#xff0c;每个盘片都有2个面&#xff0c;每个盘片都有一个对应的磁头&#xff0c;我们的磁头横移和盘面的旋转就可以读写到盘面的每一个位置&#xff0c…

新闻每天都在更新,那网页上的新闻页面是怎么使用Dreamweaver制作的?

新闻每天都在更新&#xff0c;那网页上的新闻页面是怎么使用Dreamweaver制作的&#xff1f; 新闻有很多种&#xff0c;但大多数结构都差不多&#xff0c;我们就先做一个简单的新闻页面&#xff0c;如图1中画圈圈的新闻内容。 图1 案例实现 新闻页面一般由四个部分构成&#…