研发效率破局之道阅读总结(3)工程优化

news2025/4/23 8:40:50

研发效率破局之道阅读总结(3)工程优化


Author: Once Day Date: 2025年4月22日

一位热衷于Linux学习和开发的菜鸟,试图谱写一场冒险之旅,也许终点只是一场白日梦…

漫漫长路,有人对你微笑过嘛…

全系列文章可参考专栏: 程序的艺术_Once-Day的博客-CSDN博客


注: 本文内容摘抄于原文,文中"我"代表原作者【葛俊】大佬视角。


参考文章:

  • 研发效率破局之道

文章目录

  • 研发效率破局之道阅读总结(3)工程优化
        • 1. 软件研发环境
        • 2. 如何做好代码审查
        • 3. 如何处理技术债
        • 4. 测试如何应对新的开发模式
        • 5. 各种部署的定义

1. 软件研发环境

按照开发流程,软件研发需要以下几种环境:

  • 开发机器;
  • IDE;
  • 开发过程中使用的各种工具、数据和配置;
  • 本地环境、联调环境;
  • 测试环境、类生产环境

Facebook 从不吝啬在开发机器上的投资。每个开发人员除了有一台笔记本外,还在远程数 据中心有一台开发机器。数据中心的机器用于后端以及网站的开发,为方便描述,我称之为 后端开发机。而笔记本有两个用处:一是用来做移动端 App 的开发;二是作为终端,连接 到后端开发机做后端和网站开发。

两台机器的配置都非常强劲。后端开发机一开始是实体机器,后来为了便于管理和提高资源利用率,逐步转为了虚拟机,但不变的是配置依然强大。在 2015 年的时候,绝大部分机器 配置都能达到 16 核 CPU 、144G 内存。笔记本有两种选择,一种是苹果 MacBook Pro, 另一种是联想 ThinkPad,都是当时市场上顶配或者顶配下一级的配置。

配置高效的研发环境主要包括以下几条原则:

  • 舍得投入资源,用资源换取开发人员时间。
  • 对环境的获取进行服务化、自助化。
  • 注重环境的一体化、一致性,也就是要把团队的最佳实践固化下来。
2. 如何做好代码审查

做好代码审查的一个前提条件就是,要找到适合自己团队的方法。

按照定义,人工检查才是代码审查。机器进行的检查一般叫作代码检查或者代码自动检查。

代码审查的作用很多,主要表现在 5 个方面。

  • 尽早发现 Bug 和设计中存在的问题。我们都知道,问题发现得越晚,修复的代价越大。代码审查把问题的发现尽量提前,自然会提高效能。
  • 提高个人工程能力。不言而喻,别人对你的代码提建议,自然能提高你的工程能力。事实上,仅仅因为知道自己的代码会被同事审查,你就会注意提高代码质量。
  • 团队知识共享。一段代码入库之后,就从个人的代码变成了团队的代码。代码审查可以帮助其他开发者了解这些代码的设计思想、实现方式等。
  • 针对某个特定方面提高质量。一些比较专业的领域,比如安全、性能、UI 等,可以邀请专家进行专项审查。另外,一些核心代码或者高风险代码,也可以通过团队集体审查的方式来保证质量。
  • 统一编码风格。

按照审查方式,代码审查可以分为工具辅助的线下异步审查和面对面审查两类。

  • 工具辅助的线下异步审查,就是代码作者通过工具将代码发送给审查者,审查者再通过工具把反馈传递给作者。可以控制审查时间,减少对自己工作的干扰,会留下文档,方便以后参考。
  • 面对面审查,就是审查者和代码作者在一块儿阅读代码,进行实时讨论。这种方式的好处是快,可以高效地审查不方便用文字讨论的代码。比如,架构问题的讨论就很适合用这种方式。

事实上,有调查显示,代码审查更容易发现架构问题而不是 Bug。所以我的建议是,尽量使用代码设计时审查。具体的方法是,可以使用与门禁代码检查相同的工具,只不过这个时候发出去的 PR 目的是为了讨论,而不是为了入库。讨论结束后删除这个 PR 即可。

在这里插入图片描述

代码审查需要时间,这听起来好像是废话,但很多团队在引入代码审查时,都没有为它预留 时间。结果是大家没有时间做审查,效果自然也就不好。而效果不好又导致代码审查得不到 管理者重视,开发人员更不可能将代码审查放到自己的工作计划中。于是,形成恶性循环, 代码审查要么被逐渐废弃,要么流于形式。

管理者要明确代码审查是开发工作的重要组成部分,并记入工作量和绩效考评。这是成功引入代码审查的前提,再怎么强调都不为过。

成功推进代码审查的关键操作:

  • 代码提交的原子性,是指一个提交包含一个不可分割的特性、修复或者优化,同时这个提交要尽可能小。
  • 提高提交说明的质量,,好的格式应该包含:标题,详细描述,测试情况,与其他工具和系统相关的信息。

代码审查是两个开发者之间的技术交流,双方都要谨记互相尊重的原则。

从审查者的角度来看,在提出建议的时候,一定要考虑代码作者的感受。最重要的一点是, 不要用一些主观标准来评判别人的代码。

在打回提交的时候,一定要礼貌地描述原因。审查要尽量及时,如果不能及时审查要告知作者。

代码审查常常出现问题的一个地方是,在审查过程中因为意见不同而产生争执甚至争吵,所以一定记住代码审查的目的是讨论,而不是评判。讨论的心态,有助于放下不必要的自尊心,从而顺利地进行技术交流,提高审查效率。另外,讨论的心态也能促进大家提早发出审查,从而尽早发现结构设计方面的问题。

审查者切记不要说教,说教容易让人反感,不是讨论的好方法。审查者提意见即可,不一定要提供解决方法。我曾经见过一个团队要求提出问题必须给出对应的答案,结果是大家都不愿提问题了。

想办法增加讨论的有趣性。

3. 如何处理技术债

第一方面,要利用技术债的好处,必要时要大胆“举债前行”。也就是说,在机会出现时, 使用最快的方式完成业务服务用户,抢占市场先机,“不要在意那些细节”。

第二个方面,要控制技术债,在适当的时候偿还适当部分的技术债。

控制技术债主要有以下 4 步:

  • 让公司管理层意识到偿还技术债的重要性,从而愿意投入资源;
  • 采用低成本的方式去预防;
  • 识别技术债并找到可能的解决方案;
  • 持续重构,解决高优先级技术债。
4. 测试如何应对新的开发模式

测试可以保证产品质量,重要性不言而喻。但,要做好测试也比较困难,需要克服很多挑 战。尤其是,持续交付、敏捷开发等开发模式为传统软件测试方式带来了更大的时间压力。

我们先来看看下面这种熟悉的测试方式都有什么问题:

测试人员接到项目后参与需求评审, 然后根据需求文档写用例、准备脚本,等开发提测之后正式开始测试、提 Bug、回归,测 试通过后就结束了,项目交给运维上线,之后投入下一个项目继续重复这样的流程。

这样的流程看似没什么错,但有两大问题:

  • 测试人员非常被动。当需求质量、开发质量较差的时候,测试人员只能被动接受。
  • 但同时,测试又被认为是质量的责任人。如果因为需求质量、开发提测质量差而导致上线 延期,大家通常会首先怪罪测试团队。

这些问题,在新的开发模式下愈发严重。因为这些新的开发模式有一个共同点,就是要缩短 产品的交付周期,对自动化的要求越来越高,能够专门留给传统竖井流程中测试环节的时间 越来越短,自然更难保证质量。

测试左移和右移,就是把测试的范围从传统测试的节点中释放出来,向左和右扩展。

  • 向左扩展,就是让测试介入代码提测之前的部分。比如,扩展到开发阶段,在架构设计时就考虑产品的可测试性,并尽量进行开发自测等。另外,测试可以更进一步扩展到需求评审阶段,让测试人员不只是了解需求,更要评估需求的质量,比如分析需求的合理性以及完整性等。
  • 测试右移,是让测试介入代码提测之后的部分。比如,测试人员在产品上线过程中,利用线上的真实环境测试。另外产品上线之后,测试人员仍然介入,通过线上监控和预警,及时发现问题并跟进解决,将影响范围降到最低。这样一来,测试人员不但有更多的时间进行测试,还能发现在非生产环境中难以发现的问题。

要做好测试左移,有 3 个基本原则:

  • 调整团队对测试的态度。一个有效的办法是,按照功能的维度管理团队,让整个功能团队对产品负责。也就是说,如果产品质量出现问题, 不只是测试团队“背锅”,而是会影响整个功能团队的绩效。
  • 把测试添加到开发和产品需求步骤中。常用的办法是,让测试人员参与到开发阶段的方案设计中,了解开发的实现方式。因为很多开发人员可能只熟悉他负责的那一部分,而测试人员往往对全局更加了解,所以测试人员要评估改动范围以及是否有遗漏的模块 和系统。
  • 频繁测试,快速测试。在测试左移之前,我们需要等待提测,比较被动,不能频繁测试。但测试左移到开发阶段之后,我们就有了很大的自由度去频繁运行测试,从而更好地发挥测试的作用,尽早发现更多的问题。

测试左移,本质上是尽早发现问题、预防问题。基本原则包括:从人的角度出发,让产 品、开发、运维人员统一认识,重视测试;从流程上,让测试融入产品设计和开发步骤中; 快速测试、频繁测试。

其实,软件开发行业早就达成了共识,问题发现得越晚,修复代价越大

5. 各种部署的定义

蓝绿部署(Blue-green Deployment)、红黑部署(Red-black Deployment)和灰度发布(Gray Release ,或 Dark Launch)的定义和流程:

(1)蓝绿部署,是采用两个分开的集群对软件版本进行升级的一种方式。它的部署模型中包括一 个蓝色集群 A 和一个绿色集群 B,在没有新版本上线的情况下,两个集群上运行的版本是 一致的,同时对外提供服务。

  • 首先,从负载均衡器列表中删除集群 A,让集群 B 单独提供服务。
  • 然后,在集群 A 上部署新版本。
  • 接下来,集群 A 升级完毕后,把负载均衡列表全部指向 A,并删除集群 B,由 A 单独提供服务。
  • 在集群 B 上部署完新版本后,再把它添加回负载均衡列表中。

(2)红黑部署,与蓝绿部署类似,红黑部署也是通过两个集群完成软件版本的升级。当前提供服务的所有机器都运行在红色集群 A 中,当需要发布新版本的时候:

  • 先在云上申请一个黑色集群 B,在 B 上部署新版本的服务;
  • 等到 B 升级完成后,我们一次性地把负载均衡全部指向 B;
  • 把 A 集群从负载均衡列表中删除,并释放集群 A 中所有机器。

(3)灰度发布,也被叫作金丝雀发布。与蓝绿部署、红黑部署不同的是,灰度发布属于增量发布方法。也就是说,服务升级的过程中,新旧版本会同时为用户提供服务。

灰度发布的具体流程是这样的:在集群的一小部分机器上部署新版本,给一部分用户使用, 以测试新版本的功能和性能;确认没有问题之后,再对整个集群进行升级。简单地说,灰度 发布就是把部署好的服务分批次、逐步暴露给越来越多的用户,直到最终完全上线。

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

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

相关文章

metasploit(2)生成dll木马

声明!本文章所有的工具分享仅仅只是供大家学习交流为主,切勿用于非法用途,如有任何触犯法律的行为,均与本人及团队无关!!! 一、dll文件基本概念 DLL 是一种包含可由多个程序同时使用的代码和数…

数据结构--并查集-高效处理连通性问题

目录 一、理论基础 (1)并查集的功能及实现原理 (2)代码模版 (3)模拟过程 (4)应用 二、基础题练习 (1)寻找存在的路径(模版题) …

WPS Office安卓版云文档同步速度与PDF转换体验测评

WPS Office安卓版是很多人常用的移动办公软件。它支持在线编辑、文档同步、格式转换等功能,适合手机和平板用户随时处理文档。我们用它配合谷歌浏览器打开网页文档时,也可以将内容快速保存到云端或转换成PDF格式使用。 先说云文档同步。在打开WPS Office…

Eureka、LoadBalance和Nacos

Eureka、LoadBalance和Nacos 一.Eureka引入1.注册中心2.CAP理论3.常见的注册中心 二.Eureka介绍1.搭建Eureka Server 注册中心2.搭建服务注册3.服务发现 三.负载均衡LoadBalance1.问题引入2.服务端负载均衡3.客户端负载均衡4.Spring Cloud LoadBalancer1).快速上手2)负载均衡策…

【Linux网络】构建基于UDP的简单聊天室系统

📢博客主页:https://blog.csdn.net/2301_779549673 📢博客仓库:https://gitee.com/JohnKingW/linux_test/tree/master/lesson 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! &…

【每天一个知识点】大模型的幻觉问题

“大模型的幻觉问题”是指大语言模型(如GPT系列、BERT衍生模型等)在生成内容时,产生不符合事实或逻辑的虚假信息,即所谓的“幻觉”(hallucination)。这在诸如问答、摘要、翻译、代码生成等任务中尤其常见。…

[大模型]什么是function calling?

什么是function calling? 大模型的 ​​Function Calling​​(函数调用)是一种让大语言模型(如 GPT、Claude 等)与外部工具、API 或自定义函数交互的机制。 它的核心目的是让模型能够根据用户的需求,​​…

Java高频面试之并发编程-05

hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝🐶 面试官:线程有哪些调度方法? 在Java中,线程的调用方法主要包括以下几种方式,每种方式适用于…

野外价值观:在真实世界的语言模型互动中发现并分析价值观

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

【Linux】47.高级IO(1)

文章目录 1. 高级IO1.1 五种IO模型1.2 高级IO重要概念1.2.1 同步通信 vs 异步通信1.2.2 阻塞 vs 非阻塞 1.3非阻塞IO1.3.1 fcntl1.3.2 实现函数SetNoBlock1.3.3 轮询方式读取标准输入1.3.4 I/O多路转接之select1.3.4.1 初识select:1.3.4.2 select函数原型1.3.4.3 理…

notepad++技巧:查找和替换:扩展 or 正则表达式

notepad 有很多优点:多标签,代码高亮,我最喜欢的是查找和替换。 除了可以一次性查找所有打开文件,还可以使用 扩展 or 正则表达式。 例如: 去掉空行:正则表达式: ^\s*$\r\n ^ 表示行首。\s*…

【图像标注技巧】目标检测图像标注技巧

介绍一些图像标注技巧。之前引用过别人的文章 yolo目标检测 技巧 trick 提升模型性能,deep research检测调研报告也可以进行参考。 拉框类的标注,如果你不确定哪种方法好,你可以把所标注区域的都剪切出来,然后站在屏幕一米之外眯…

MuJoCo中的机器人状态获取

UR5e机器人xml文件模型 <mujoco model"ur5e"><compiler angle"radian" meshdir"assets" autolimits"true"/><option integrator"implicitfast"/><default><default class"ur5e">&…

测试第四课---------性能测试工具

作者前言 &#x1f382; ✨✨✨✨✨✨&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f367;&#x1f382; ​&#x1f382; 作者介绍&#xff1a; &#x1f382;&#x1f382; &#x1f382; &#x1f389;&#x1f389;&#x1f389…

【C++】新手入门指南(下)

文章目录 前言 一、引用 1.引用的概念和定义 2.引用的特性 3.引用的使用 4.const引用 5.指针和引用的关系 二、内联函数 三、nullptr 总结 前言 这篇续上篇的内容新手入门指南&#xff08;上&#xff09;&#xff0c;继续带大家学习新知识。如果你感兴趣欢迎订购本专栏。 一、…

前后端分离项目在未部署条件下如何跨设备通信

其实我此前也不知道这个问题怎么解决&#xff0c;也没有想过—因为做的项目大部分都是前后端分离的&#xff0c;前端直接用后端的部署好的环境就行了。最近也是有点心高气傲开始独立开发&#xff0c;一个人又写前端又写后端也是蛮累的&#xff0c;即使有强有力的cursor也很累很…

基于Python的多光谱遥感数据处理与分类技术实践—以农作物分类与NDVI评估为例

多光谱遥感数据包含可见光至红外波段的光谱信息&#xff0c;Python凭借其丰富的科学计算库&#xff08;如rasterio、scikit-learn、GDAL&#xff09;&#xff0c;已成为处理此类数据的核心工具。本文以Landsat-8数据为例&#xff0c;演示‌辐射校正→特征提取→监督分类→精度评…

vscode python 代码无法函数跳转的问题

TL; DR; python.languageServer 配置成了 None 导致 vscode python 代码无法函数跳转 详细信息 mac 环境下 vscode 正常 command 鼠标左键 可以跳转到定义或者使用位置&#xff0c;但是我的为何不知道失效了 我一开始以为是热键冲突&#xff0c;结果发现 mac 好像没办法定…

Unity 脚本使用(二)——UnityEngine.AI——NavMesh

描述 Singleton class 用于访问被烘培好的 NavMesh. 使用NavMesh类可以执行空间查询&#xff08;spatial queries&#xff09;&#xff0c;例如路径查找和可步行性测试。此类还允许您设置特定区域类型的寻路成本&#xff0c;并调整寻路和避免的全局行为。 静态属性&#xff0…

从项目真实场景中理解二分算法的细节(附图解和模板)

遇到一个真实场景里使用二分算法的问题&#xff0c;本以为可以放心交给小师弟去做&#xff0c;结果出现了各种问题&#xff0c;在此梳理下二分算法的核心思想和使用细节。 文章目录 1.场景描述2.场景分析3.二分算法的精髓3.1 核心模板3.2 二分过程图解3.3 各种区间写法3.3.1 闭…