阿里微服务质量保障系列(二):研发流程知多少

news2025/1/9 16:01:12

持续坚持原创输出,点击蓝字关注我吧

介绍研发流程主要是给大家一个体感,可以直观感受阿里测试工程师从项目的立项到最终发布经历了哪些过程、做了什么工作。

需求的产生

刚毕业工作那会,认为需求来源于产品,把PD宣讲的产品需求奉为圭臬,很少去质疑,随着工作经验的丰富,逐渐认识到需求的产生其实是来源于市场,PD也只不过是市场需求的“搬运工”和提炼者

因此,平时做项目的时候,还是要了解下市场的情况,多思考需求的背景、需要解决的问题以及能取得什么产出。

我目前所在的团队做的业务属于中台型的,可以简单理解为服务的“客户”就是上游调用我们服务的团队,这里叫“行业产品”,他们是能直接产生经济效益的,技术层面上来说行业是通过对中台提供的各种微服务进行编排以对外提供某种产品能力。因此, 中台的很多需求来源于行业,至少我这一年来做的项目大多数是配合行业做的,中台另外一部分需求就是来源于“自我革新”,即架构升级。

总结下来中台的需求来源就是行业层需求+中台自我架构升级。因此,中台的建设也存在想完全摆脱业务但又无法摆脱的矛盾。

这种情况难受的不止开发(需要做一些特殊业务的兼容),对测试来说更难受,线上很容易出现一些意想不到的“惊喜”。这也是当前项目测试中存在的难点,目前也没有很好的办法,只能靠专家经验。

架构设计

架构设计一般是组内的高P来搞,相对于一线干活的低P,他们往往大局观更强,架构设计的更为合理(高p大多工作多年,对系统有深入了解)。

当然架构设计也不是必须的环节,一些不涉及架构变动的项目一线开发同学就足以解决了,高P更多是参与代码Review。

系分评审

大项目会优先评审架构,然后各域评审系分。

系分评审之前,各域会做契约对齐,没问题后才开始评审。

系分评审内容重点是上下游的调用链路变动分析(时序图),新功能的实现逻辑(代码变动、领域模型变动、数据模型变动),兼容性分析。

不同的开发写的系分文档质量也不近相同,但系分文档通常包含以下模块:

  1. 需求背景

  1. 需求分析

  1. 实现目标

  1. 架构分析

  • 当前架构分析

  • 目标架构分析

  • 上下游依赖分析

  • 数据模型分析

  1. 链路变更分析

  • 现状分析

  • 目标链路分析

  • 具体变更流程

  1. 兼容性分析

  1. 配置变更分析

系分评审的重点是 需求怎么实现,对存量业务的影响分析。

测分评审

在第一家公司的时候,当时写的是测试方案,其实和测试分析算是一个东西的两种不同叫法。测分一般是在系分评审后开始写,通常一天左右可以搞定。测分主要包含以下内容:

  1. 需求分析

  1. 变更分析(现状、目标时序图、改造功能流程图)

  1. 测试场景分析

  1. 正常流程

  1. 异常流程

  1. 幂等分析

  1. 风险点分析

  1. 兼容性分析

  1. 非功能测试

  1. 资损分析

  1. 测试用例

测分评审内容侧重点在于测试什么、该怎么测、潜在风险点。

开发联调

开发联调一般是上游发起的e2e测试。

通过联调测试验证上下游的契约是否对齐。

联调内容一般是业务的主链路场景。

域内测试/e2e测试

一般是用项目分支提测,特殊情况下,例如项目比较赶时间,也是可以在开发分支提测。

项目分支:用于直接合并到master的分支
开发分支:开发新feature的分支。

域内测试就是单域(服务)测试,例如金融域。需要注意的是单域并非单接口,域和接口是一对多的关系,也就是说单域包含多个接口对外提供不同的服务,只是这些接口业务比较相近,统一划归到某个域了。因此,域内测试可以等同于接口测试,微服务下更多是非Http协议实现的接口,例如基于TCP协议的RPC。所以市面上的接口测试工具,如postman,jmeter都不能直接拿来用了,需要测试同学搭建符合自己需求的测试框架。域内测试重点关注单域功能质量,因此需要mock掉依赖的下游服务。

e2e测试就是通常说的端到端测试,是一种用于测试整个应用程序的流程是否符合预期的测试技术。重点关注输入输出的黑盒测试手段。

e2e测试一般是行业的测试同学(主测试)发起,平台测试需要关注e2e测试过程中的所在域的报错并帮忙排查原因,以及落单的数据是否正确。

平台测试:单域功能的测试同学,负责单域的质量保证。
主测试:一般是行业的同学,整个项目的测试owner,把控项目整体质量,每日同步各平台 测试的进度与风险。

回归测试

回归测试的内容包含 新功能与存量功能的回归。

回归的手段目前有域内自动化case、流量回放工具。

预发布

预发环境一般是产品同学用于测试验证的“生产环境”,预发就是把代码发布到预发环境。

灰度发布

灰度发布也称为金丝雀发布(Canary releas)是版本升级平滑过渡的一种方式,当版本升级时,使部分用户使用新版本,其他用户继续使用老版本,待新版本稳定后,逐步扩大范围把所有用户流量都迁移到新版本上面来。这样可以最大限度地控制新版本发布带来的业务风险,降低故障带来的影响面,同时支持快速回滚。

对于测试来说,灰度过程需要关注下 报警日志,分析下报错原因,确认是否是本期代码变更导致。

生产发布

生产发布,就是将本期代码变更推到全部的生产服务器上,所有用户的请求会走到新代码,至此 整个项目流程也就就结束了。

关于灰度发布vs蓝绿发布区别

灰度发布

灰度发布的介绍可以见上文,这里不做赘述。下面介绍下蓝绿发布。

蓝绿发布

蓝绿发布提供了一种零宕机的部署方式,是一种以可预测的方式发布应用的技术,目的是减少发布过程中服务停止的时间。在保留老版本的同时部署新版本,将两个版本同时在线,新版本和老版本相互热备,通过切换路由权重的方式(非0即100)实现应用的不同版本上线或者下线,如果有问题可以快速地回滚到老版本。

- END -


下方扫码关注 软件质量保障,与质量君一起学习成长、共同进步,做一个职场最贵Tester!

  • 后台回复【测开】获取测试开发xmind脑图

  • 后台回复【加群】获取加入测试社群方式

往期推荐

聊聊工作中的自我管理和向上管理

经验分享|测试工程师转型测试开发历程

聊聊UI自动化的PageObject设计模式

细读《阿里测试之道》

我在阿里做测开

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

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

相关文章

12.30第一周 星期五SSH

SSH功能:1.远程连接 2.sftp 1. 使用之前首先确认系统中有无 ssh 的软件包 rpm -qa | grep ssh 主程序或执行文件位置:/usr/sbin/ss服务端配置文件: /etc/ssh/sshd_config服务器用客户端的公钥对数据---->加密---->到客户端时&#xf…

TemplateFlow:一个跨物种,多尺度脑部模板和图谱的共享平台

Problem大脑的参考模板在神经影像工作流程中起着核心作用,是报告标准化结果的基础。而模板或者图谱的选择是不同研究中方法学差异的一个相关来源,最近被认为是对神经科学可重复性的一个重要挑战而受到关注。大多数情况下,我们所使用的模板由神…

Linux中Shell与环境变量与配置文件

Shell是什么 Shell是个程序,他会在用户登录系统后系统开启的,他可以通过标准输入来接收命令,然后执行命令,Shell可以执行内部命令和外部命令,内部命令就是Shell程序里面自己的逻辑,外部命令是Shell调用其他…

Linux常用命令——firewall-cmd命令

在线Linux命令查询工具 firewall-cmd Linux上新用的防火墙软件,跟iptables差不多的工具。 补充说明 firewall-cmd 是 firewalld的字符界面管理工具,firewalld是centos7的一大特性,最大的好处有两个:支持动态更新,不…

【SCL】博图scl语言应用项目:装配流水线模拟控制

使用西门子博图SCL语言和factoryio软件来编写应用案例——装配流水线模拟控制项目 文章目录 目录 前言 一、应用:装配流水线模拟控制 1.控制要求 2.完善控制要求和场景 1.布置场景(factoryio) 2.控制要求 3.变量表(I/O分配&…

Cocos Creator Protobuf的js版本使用

一、基础知识参考Protocol Buffers 在游戏中的应用Protobuf语言指南android与PC,C#与Java 利用protobuf 进行无障碍通讯【Socket】1.性能好/效率高现在,俺就来说说Google公司为啥放着好端端的XML不用,非要另起炉灶,重新造轮子。一…

10.0、Linux-磁盘管理简单初体验

10.0、Linux-磁盘管理简单初体验 列出文件系统整体的磁盘使用量 -> df -h ( 检查磁盘空间使用量 ) 查看目录中所有的文件磁盘空间使用情况 -> du -a -h 根目录下每个目录所占空间大小容量 -> du -sm /* Mac 或者想使用 Linux 挂载我们的一些本地磁盘或者文件 挂载&am…

时隔 20 年,这个编程语言再次“称王”!

↓推荐关注↓综合整理:程序员的那些事(id: iProgrammer)近日,全球知名的编程语言流行度排行榜网站 TIOBE 公布了 1 月编程指数信息。前三的编程语言是Python、C 和C,第四为Java,第五是C#。TIOBE 的 2022 年…

MyBatis#1(快速入门与Mapper代理)

一.MyBatis简介1.MyBatis是一款优秀的持久层框架,可用于简化JDBC的开发2.持久层: 负责将数据保存到数据库的那一层代码JavaEE的三层架构: 表现层, 业务层, 持久层3.框架:框架就是一个半成品软件, 是一套可重用的, 通用的, 软件基础代码模型优点: 高效, 规范, 通用, 可扩展二.My…

ESP32设备驱动-BMP180气压温度传感器驱动

BMP180气压温度传感器驱动 1、BMP180介绍 BMP180 是Bosch Sensortec 新推出的数字气压传感器,性能非常高,可用于智能手机,平板电脑和运动设备等高级移动设备。它遵循BMP085并带来许多改进,如较小的尺寸和数字接口的扩展。超低功耗低至3μA,使BMP180成为移动设备节能的领…

EfficientFormer: Vision Transformers at MobileNet Speed

Paper name EfficientFormer: Vision Transformers at MobileNet Speed Paper Reading Note URL: https://arxiv.org/pdf/2206.01191.pdf TL;DR 本文目标是回答一个问题:transformer 是否可以在比 cnn 运行更快的时候同时精度更高?本文提出了 Effic…

3. R获取数据的三种途径、读入文件、写入文件、读写excel文件、读写R文件

课程视频链接:https://www.bilibili.com/video/BV19x411X7C6?p1 本笔记参照该视频,笔记顺序做了些调整【个人感觉逻辑顺畅】,并删掉一些不重要的内容 系列笔记目录【持续更新】:https://blog.csdn.net/weixin_42214698/category_…

后端人眼中的Vue(三)

五、高级 5.1、计算 5.1.1、computed ​ 在之前的购物车的案例当中,我们已经实现了购物车价格的计算,但是有些时候我们需要在其他很多地方也展示价格,所以每展示一次,我们就需要调用一次计算价格的方法,所以Vue给了…

OV7670 摄像头模块介绍

OV7670摄像头模块简介OV7670是OV(OmniVision)公司生产的一颗1/6寸的CMOSVGA图像传感器。该传感器体积小、工作电压低,提供单片VGA摄像头和影像处理器的所有功能。通过SCCB总线控制,可以输出整帧、子采样、取窗口等方式的各种分辨率…

Visio 学习笔记 —— Visio 的键盘快捷方式

Visio 学习笔记 —— Visio 的键盘快捷方式常用热键常用对话框文本操作快速访问工具栏参考资料常用热键 操作热键指针工具Ctrl 1文本工具Ctrl 2连接线Ctrl 3连接点工具Ctrl Shift 1裁剪工具Ctrl Shift 2文本块工具Ctrl Shift 4组合所选的形状Ctrl G解散组合Ctrl Sh…

Verilog语法笔记(夏宇闻第三版)-结构说明语句

目录 initial语句: always语句: task和function说明语句: task和function说明语句的不同点: task说明语句: function说明语句: Verilog语言中的任何过程模块都从属于以下四种结构的说明语句&#xff…

【GNN】图基本知识代码、nxworks包的基本使用

一个写得很好的博客: 图或网络中的中心性:点度中心性、中介中心性、接近中心性、特征向量中心性、PageRank 特征向量中心性(eigenvector centrality) 特征向量中心性的基本思想是,一个节点的中心性是相邻节点中心性的函…

Reactive思考

最近在学习响应式编程,由此翻看了很多资料,在此把思考过程记录下 目录 来由 规范 具体实现 历史 1. Servlet的尝试 1.1 Async实现demo 2. web应用层 2.1 web-flux 2.2 web-flux/web-mvc 与 spring-web架构关系 3. DBConnection层 相关可能混淆…

STL中vector怎么扩容

STL vector扩容 vector容器 vector被称为向量容器,该容器擅长在尾部插入或删除元素,时间复杂度为O(1);而对于在vector容器头部或者中部插入或删除元素,则花费时间要长一些(移动元素需要耗费时间)&#xf…

十九、Kubernetes中Pod调度第一篇

1、概述 在默认情况下,一个Pod在哪个Node节点上运行,是由Scheduler组件采用相应的算法计算出来的,这个过程是不受人工控制的。但是在实际使用中,这并不满足的需求,因为很多情况下,我们想控制某些Pod到达某些…