架构愿景: 构建良好软件的关键

news2024/11/29 10:00:12

在产品开发生命周期的各个阶段,牢记架构愿景,始终坚持每个决策都符合愿景原则,是避免架构腐化的唯一方式。原文: Architecture Vision — A critical ingredient in building well-maintained software

上一篇文章《软件架构: 一切皆有代价》讨论了成功软件的陷阱,如果不把软件架构作为一流公民和敏捷团队日常工作的关键要素,软件的发展将被置于危险路径。本文将讨论架构愿景如何帮助团队保持架构的健康状态,不断应对业务挑战。

本文将更多的阐明架构愿景,我相信这可能是构建和维护软件系统的好方法。此外,还将提供开发架构愿景的模板,其中指定了愿景的主要组件,并可以根据特定需求进行定制。

敏捷世界中的架构愿景

alt

愿景通常被描述为"想象力的力量",可以让我们创造未来的心理形象,作为行动指南,并提供目的感。因此,愿景在塑造未来和帮助实现目标方面发挥着至关重要的作用。

"为了采取积极的行动,必须建立积极的愿景。"

架构愿景表示一种理想架构,可以实现满足功能和质量需求的系统。这个一理想图景可以作为目标,为下一版架构提供指导方针和动力。架构愿景试图确保后续版本对软件架构有积极(或至少没有消极)的影响。在每次发布期间,都要努力接近架构愿景所定义的理想状态,因此最新架构的理论可靠性应该比前一个更高。

理想情况下,在开发过程早期创建架构愿景,在整个开发过程中作为团队的参考点,以确保所构建的系统与最初愿景一致。开发过程中,应根据需要对其进行审查和更新,以确保保持相关性和准确性。愿景可以作为与变更相关的指南,帮助维护原始目标,并帮助避免导致架构侵蚀和漂移问题的陷阱。架构愿景有助于保持架构文档的更新,并提高实现下一版本目标的能力。

是否真有可能实现架构愿景目标并不重要,至少有理想的目标可以为之奋斗,作为参考点审查和更新已实现的体系架构,并增加实现下一版本目标的能力。

alt

在软件开发初始阶段,架构愿景有助于获得组织高层管理的承诺,使他们充满信心。此外,有助于在项目开始时以及在开发和管理阶段使架构团队保持一致。此外,在组织层次上,愿景有助于为架构获取更广泛的支持。架构愿景支持软件架构来定义系统范围,指导构建和管理决策。

架构愿景总是基于业务愿景编写,随着业务发展以及环境和技术的变化,需要使架构愿景与需求和业务愿景保持一致,因此需要更新和发展架构愿景

当然,还有其他不同的方法,比如架构模式、架构表示语言、scrum开发方法等等。架构愿景并不是一种新模式,相反,它是一种技术或规范,可以在敏捷流程中执行,根据业务目标以及过去和未来的需求,对应用健康状况进行一致、迭代的检查。

"好的软件架构为团队提供清晰、共享的愿景,使团队能够朝着共同的目标一起工作。" —— Jim Highsmith

构建架构愿景

那接下来的重要问题是,如何创建架构愿景,应该遵循哪些步骤,哪些事情需要考虑?

alt

创建架构愿景没有硬性规定或技术,完全取决于业务领域、组织或项目需求。在不同类型的业务领域和组织中,构建架构愿景时需要考虑不同方面,以获得最大好处。

让关键利益相关者参与软件架构愿景开发很重要,因为所选架构会对他们产生影响,并且他们可以提供有价值的输入和见解。这些相关者可能包括业务领导、技术人员和最终用户。当然,如果让包括敏捷团队、管理层和客户在内的所有关键利益相关者都知道架构愿景的重要性,那将非常有价值。

以下是一些常见的指导原则:

业务和技术目标: 创建架构愿景应该考虑长期目标。业务和相关架构目标以及满足这些目标的对象也应该记录下来。架构愿景的开发是非常关键的步骤,必须集中精力编写目标应用的理想(但现实的)图景。

用户需要和需求: 架构应该满足将要与之交互的用户的需要和需求。软件架构愿景还应考虑功能和质量需求,例如性能、可伸缩性、安全性和可维护性。

现有系统和架构: 这是现在所有的,坚持从小处开始,避免从一开始就过度架构。架构愿景应该考虑系统的当前状态,以及新架构如何与这些元素集成或替换。

行业趋势和最佳实践: 在开发体系架构时,很重要的一点是要考虑行业趋势和最佳实践,从而为设计提供有用信息,并帮助确保体系架构的有效和高效。

架构约束: 架构约束需要在系统架构的开发、维护和管理期间得到满足。约束通常是在不同层次上定义,比如企业级、特定于项目的约束(如资源、时间、成本)等。架构愿景需要确保软件架构在任何版本中都不会违反这些约束中的任何一个。

架构原则和框架: 在软件架构和开发生命周期中需要遵循符合架构原则的目标框架。框架从架构愿景中获得灵感,帮助架构以一致方式遵循框架和原则。根据经验,如果团队能够遵循公司或领域的架构原则,囊括其他相关重要原则,在架构愿景中以更具体的形式将这些原则定义出来,将会有莫大的帮助。

应用程序标准: 在整个开发生命周期中需要遵循的应用程序标准可以定义在架构愿景中,并在不同版本中遵循。这些应用标准包括编码标准、命名约定、代码文档标准、体系架构标准等。

体系架构风格: 架构愿景可以包含架构师想要为应用程序采用的架构风格。无论架构师使用什么风格,重要的是在不同版本中都获得遵循。对架构风格的违背将导致架构被侵蚀。

所用技术: 架构师用于应用开发的目标技术可以记录在架构愿景中。许多情况下,软件架构是通过考虑目标技术来构建的,架构中包含了许多特定于技术的东西。因此,通过记录架构愿景中使用的技术,可以在设计以后的版本时通盘考虑。

预算和资源: 预算和可用资源将影响架构的范围和复杂性。在开发架构愿景时,考虑这些约束很重要,当前和未来可用资源的信息对架构师在设计不同版本的架构时非常有帮助。

架构设计决策: 有助于在软件系统的整个生命周期中组织和管理体系架构设计决策。

活动

沟通愿景

在实现软件架构愿景的过程中,沟通架构愿景是重要的一步。包括向利益相关者展示愿景,并获得认可和支持清晰有效的沟通愿景的好处及其将如何支持组织目标是很重要的方面。

建议花些时间确定所有将受到软件架构愿景影响的关键利益相关者,包括业务领导、IT人员和最终用户,他们有不同的需求和关注点,应该在沟通过程中加以解决。

架构愿景研讨会
alt

研讨会的主要目的是根据业务愿景绘制应用程序的理想架构。团队对业务的未来发展方向以及如何构建遵循业务目标的技术功能(应用程序)达成共同理解。团队聚集在一起讨论应用程序的当前形态以及将来期望达成的目标。

日程

会议议程如下:

  • 跟进之前的行动。
  • 当前实现的架构是什么样的。
  • 理想架构是什么样的?基于短期和长期业务需求,希望将架构发展到什么程度?
  • 是否需要根据最新业务目标对当前的理想架构进行任何更改?
  • 未来可以采取哪些新的步骤来接近理想架构?
  • 新的行动
  • 开放式讨论

输出

以下是研讨会的主要成果:

  • 共同理解并记录应用或平台的理想体系架构。
  • 应用体系架构的当前状态。
  • 为接近理想架构而采取的步骤或行动。
  • 共享和修改对业务目标的理解。

频率

  • 建议召开会议的频率为每月一次或至少每季度一次。

责任

研讨会由整个团队负责,并保证活动有效。

产品负责人需要从会议中确定行动优先级,团队应该在每个迭代冲刺中留出一些时间来处理这些行动。

重要的是,业务方需要支持/赞助这些会议,没有业务方的支持,不会有多大效果。

跟进架构愿景活动

alt

愿景研讨会输出的任务列表,通常包含两种类型的任务:

  1. 隐式的(基于内在的)
  2. 显式的或基于活动的

隐式(内在): 这些是不需要显式创建的任务,更多的是关于正在进行的任务或团队成员需要开始使用的工作方式,没有必要在迭代冲刺中创建特定故事/任务。此类任务包括遵循特定编码风格/标准、遵循新出现的业务需求(故事)的架构原则或模式,等等。团队需要找到一种方法来衡量这些任务的进度,以及这些任务的"完成定义(definition of done)"是什么。

显式: 这些任务更像是需要由团队成员计划、评估和执行的活动,包括重构代码库以获得更好的设计/架构、配置新的支持工具/库、使用新的框架、新的更好的部署策略,等等。

团队需要从愿景会议中获取基于活动的任务列表,放入产品待办事项列表中。至关重要的是,团队和利益相关者需要密切关注任务列表,并在每个迭代冲刺中与其他故事一起确定优先级。

结语

alt

不可否认,愿景是生活的重要方面。然而,讽刺的是,当我们面对生活中的各种挑战时,往往忽视或忘记了愿景。就像日常生活一样,如果团队有共同的愿景,会有很大的价值。我的观点是,大多数个人和团队都有指导他们的愿景,但通常是隐含的,没有明确定义或表达,这是当我们面对交付压力,做出不同选择,从而偏离了真正的精神或价值观的主要原因。

有一种强大的力量和吸引力,使我们明确、讨论、反对、捍卫和共同建设愿景。

敏捷团队赢得了巨大的胜利,不仅是因为他们致力于架构愿景,还因为他们将愿景作为团队日常工作的关键组成部分。最重要的是,没人可以给你愿景,当然,他们可以给你一些想法,但团队需要建立和拥有自己的愿景,并根据需求、环境和挑战进一步构建,使其成为推动每个决策的关键组成部分。

没人给你愿景,是团队创造并拥有愿景,这是唯一的生存方式。


你好,我是俞凡,在Motorola做过研发,现在在Mavenir做技术工作,对通信、网络、后端架构、云原生、DevOps、CICD、区块链、AI等技术始终保持着浓厚的兴趣,平时喜欢阅读、思考,相信持续学习、终身成长,欢迎一起交流学习。微信公众号:DeepNoMind

- END -

本文由 mdnice 多平台发布

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

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

相关文章

华为OD机试真题B卷 Java 实现【字符串通配符】,附详细解题思路

一、题目描述 问题描述:在计算机中,通配符一种特殊语法,广泛应用于文件搜索、数据库、正则表达式等领域。现要求各位实现字符串通配符的算法。 要求: 实现如下2个通配符: :匹配0个或以上的字符&#xf…

“国风顶流”霸王茶姬,眺望书画诗酒的远方

一杯来自云南的原叶鲜奶茶,如何征服消费者的胃和心? 茶饮赛道素来竞争激烈,十年时间,行业从鲜奶茶卷到奶盖茶、水果茶、多料奶茶等一个又一个新品类。茶饮品牌如雨后春笋般涌现,甚至不少咖啡品牌都跨界而来&#xff0…

【新星计划回顾】第三篇学习计划-分页和排名函数的运用

🏆🏆今天是【全国科技者工作日】,在这个特别的日子里,自然要写篇文章! 最近这段时间非常忙,虽然导师首次参与新星计划活动已经在4月16日圆满结束,早想腾出时间来好好整理活动期间分享的知识点。…

实战一个react(0-1)项目

文章目录 1. 安装2. 完成一个组件开发3. 添加路由3. 引入element-react1. 运行发现报错./node_modules/element-react/dist/npm/es5/src/locale/format.js2. 接着又报错The <Router /> component appears to be a function component that returns a class instance. Cha…

ABP VNext认证授权获取Token

ABP VNext认证授权获取Token 1.Password授权方式获取1.1 请求说明1.2 请求示例1.3 请求参数 2.authorization_code模式获取2.1 无认证授权&#xff0c;跳转至授权认证中心2.2 用户密码登录2.3 登录成功&#xff0c;服务器会跳转至redirect_url所指地址 1.Password授权方式获取 …

vue-kindeditor 安装和解决问题

效果图 kindeditor 引入 一、去官网下载 kindeditor 包 官方链接 二、在vue里的static文件夹下 创建一个 文件夹名字叫 kindeditor&#xff0c; 把下载好的文件放在这里 三、在 公共组件 components 下 创建kindeditor.vue 文件 <template><div class"kindedit…

拿到字节跳动奖学金,入职字节跳动做科研,他们经历了什么?

前不久&#xff0c;第三届字节跳动奖学金计划已经正式启动。 自 2021 年起&#xff0c;字节跳动奖学金计划已经完成了两届评选&#xff0c;共有 19 位优秀学子荣获每人 10 万元人民币的奖学金。 在奖学金支持下&#xff0c;他们获得了新的科研项目费用、学术交流机会&#xff0…

高压放大器在驱动压电陶瓷进行铝板无损检测中的应用研究

想要达成在不损害或不影响被测对象使用性能及自身性质的前提下&#xff0c;对被测对象内部进行缺陷&#xff0c;结构&#xff0c;失效分析&#xff0c;就得用到无损检测&#xff08;Non Destructive Testing&#xff09;技术&#xff0c;最常用的无损检测方法有很多&#xff0c…

【网络安全知识】网络技术领域术语大全,强烈建议收藏!

自主访问控(DAC:Discretionary Access Control) 自主访问控制(DAC)是一个访问控制服务&#xff0c;其执行一个基于系统实体身份的安全政策和它们的授权来访问系统资源。 双附接集线器(DAC: Dual-attached Concentrator) 双附接集线器(DAC)是FDDI或CDDI集线器有能力接入到一个…

RK3568 AP6275S蓝牙驱动程序调度过程

1、前言 今年3月份调度了RK3568驱动程序&#xff0c;当时由于时间的问题&#xff0c;AP6275S蓝牙驱动程序没有调试成功。当时仔细检查的设备树的配置。 wireless_bluetooth: wireless-bluetooth {compatible "bluetooth-platdata";clocks <&rk809 1>;cl…

离散数学_十章-图 ( 4 ):图的表示和图的同构

&#x1f4f7;10.4 图的表示和图的同构 1. 图的表示1.1 邻接表1.1.1 简单图的邻接表1.1.2 有向图的邻接表 1.2 邻接矩阵❗在邻接表和邻接矩阵之间取舍1.3 关联矩阵 2. 图同构3. ⚡判断两个简单图是否同构 图的表示方式有很多种&#xff0c;选择最方便的表示有助于对图的处理~ …

Navicat 面向 PostgreSQL 查询超时的工具解决方案

文章目录 Navicat 面向 PostgreSQL 查询超时的工具解决方案查询超时的必要性应用场景 查询分析器 | Navicat Monitor在数据库级别设置为特定用户设置查询超时 结语 Navicat 面向 PostgreSQL 查询超时的工具解决方案 早前&#xff0c;我们发表过一篇《PostgreSQL 与 Navicat &am…

Datax ftp写入hive

这是一个巨大的坑&#xff0c;网上对这块的完整描述真的很少&#xff0c;新手真的会很迷茫&#xff01;&#xff01;&#xff01; 插件 选择插件 reader插件选择&#xff1a;ftpread write插件选择&#xff1a;hdfswrite 参数配置 reader参数 "parameter": {/…

干货|SpringCloud全家桶微服务初探

SpringCloud的从整体架构上看&#xff0c;相对来说是完整的、庞大的。它不仅仅是一个基础性架构工具&#xff0c;它为微服务架构提供了一个“全家桶”的套餐。每一个模块关注各自的职能&#xff0c;并且能够很好地配合与协作&#xff0c;能够帮助入门者快速搭建起一套微服务架构…

前后端联调跨域问题

文章目录 什么是同源策略如何判断是否同源&#xff1f;跨域资源共享(CORS)如何解决跨域问题 什么是同源策略 同源策略限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的重要安全机制。 如何判断是否同源&#xff1f; 如果…

从中国人民大学与加拿大女王大学金融硕士的学员构成,了解金融行业都有哪些职位

金融行业最受欢迎的岗位莫过于券商、银行、基金公司、私募市场、体制内&#xff08;监管部门、交易所等&#xff09;、信托、大企业投资部、保险、管理咨询、资产管理。在当下如果要选择工作&#xff0c;想找就业率第一、薪酬排名第一的行业&#xff0c;那一定是金融工作。中国…

03 redis新类型bitmap/hyperloglgo/GEO

亿级系统中常见的四种统计 聚合统计 统计多个集合元素的聚合结果&#xff0c;就是前面讲解过的交差并等集合统计交并差集和聚合函数的应用 排序统计 抖音视频最新评论留言的场景&#xff0c;请你设计一个展现列表。考察你的数据结构和设计思路设计案例和回答思路以抖音vcr最…

3.java高级之GUI编程

1.gui (graphical user interface) awt sun公司最早的gui,不美观,不兼容各平台swing : awt升级2.顶层容器(只有一个)(其他的只能放这里)Jframe Jdialog对话框 Jwindow(x) //在main方法写fnew Jframe(); f.setSize(300,300); //设置大小f.setTitle("hello"); //设置…

java条件语句

文章目录 一、java条件语句1、Java 条件语句 - if...else2、Java switch case 语句 总结 一、java条件语句 1、Java 条件语句 - if…else Java 中的条件语句允许程序根据条件的不同执行不同的代码块。 一个 if 语句包含一个布尔表达式和一条或多条语句。 语法 if 语句的语法…

你真的了解kotlin中协程的suspendCoroutine原理吗?

文章目录 什么是协程suspendCoroutineUninterceptedOrReturnsuspendCoroutineUninterceptedOrReturn存在的问题suspendCoroutinesuspendCancellableCoroutine ​ 引言&#xff1a; 在Kotlin协程中&#xff0c;如何让一个suspned 函数挂起&#xff1f;如何让挂起协程恢复&#…