2025上半年,最新 AI实践都在这!20+ 应用案例,任听一场议题就值回票价 了解详情
写点什么

来自荷兰格罗宁根大学的架构决策捕捉工具 RGT

  • 2013-01-24
  • 本文字数:2036 字

    阅读完需:约 7 分钟

格罗宁根大学的 Dan Tofan 向软件架构师提供了开源软件工具 RGT (Repertory Grid Tool),这种工具用于捕获和评估他们的架构决策。这个工具可以帮助架构师更好的文档化他们的决策及对决策进行回顾。

构建复杂软件系统通常需要作出许多重要的决策。在这些决策中,架构师们处理满足利益相关者关于各种功能和非功能需求的各种关注点,以便满足商业和技术目标。另外,架构师们需要他们回顾决策过程的质量,比如“我是否考虑了决策的所有可行的方案?”

为了帮助架构师,格罗宁根大学的软件工程研究者为架构决策提供了这个工具。关于这个开源工具的细节可以通过这个链接了解 https://github.com/danrg/RGT-tool/wiki .

InfoQ:Dan, 能否用最少的词描述下你自己和你的研究?

我是一名软件开发者,在业界工作六年后成为研究员。我研究方向主要是改进软件架构的决策。

InfoQ:你为什么要创造 RGT?以及它和你现在做的研究工作有什么联系呢?

我认为决策技能是架构师必备的技能,不只是为了设计软件,也为了向其他利益相关者说明基本原理。所以如果你把决策作为一种技能,比如游泳或者烹饪,那么下一步你就会理性的问:怎么才能改进自己的架构决策能力?

决策和获取架构决策知识是同时的。对获取的决策知识有效追踪。所以,使用 RGT 获得架构决策有两个主要优点:储备用于架构决策的知识,改进架构师的决策能力。

InfoQ:能否描述下 RGT?

RGT 通常有这些步骤。首先,我们有一个要决策的问题。第二步,找出问题的各种可选方案。第三步,我让你找出两个你觉得相似但又和另外一个不同的方案。第四步,你描述为什么这两个是相似的,和第三个又为什么是不同的。这样就产生了关注点(用 RGT 的术语叫“观点”)。Java 和 C#是类似的,因为他们都是由大厂商维护支持的,而 Ruby 只是社区维护支持的。然后产生更多的关注点,下一步是对各种可选方案按照关注点进行评分(通常从 1 到 5)。然后,各种可选方案会产生一个矩阵(或者叫网格),分析这些关注点以及评分,比如使用层序聚类分析,根据可选方案与关注点的相似性进行分组。最后,架构师可以通过更新可选方案,关注点,评分,精简这个网格。这个最终的网格可以反映这个决策的思维模型。总的来说,这个网格提供了这个决策的精炼文档。相对于一般的文字描述,这个文档更精炼地描述了决策。

InfoQ:RGT 的典型应用场景有哪些?

典型应用场景是从 4 到 9 种可选方案获得架构的决策。对太少的可选方案,RGT 可能误判。

对更多的替代方案,RGT 则可能会花费太长的时间。

InfoQ:RGT 对使用者提供了那些好处?

RGT 提供了获取决策的一种系统方法。同时,它也帮助产生关于决策的新的灵感。RGT 使架构师可以回顾他们的决策。最后,RGT 交付一个关于决策的文档。

当日,RGT 也有缺点。主要是 RGT 是花费时间的。因此,我觉得 RGT 更适用于那些需要周密考虑的重要决策,这也是软件架构师经常碰到的事情。当使用 RGT 讨论软件架构时,他们经常抱怨缺乏好的工具支撑。所以我们就创造了这个软件来解决。

InfoQ:这个工具有哪些主要特性?

首先,该工具帮助架构师网格化他们所有独立决策。第二,这个工具支持从现有的网格进行协同决策。办法是通过多轮的表格填写, 澄清各种利益者之间的各种分歧,最终达到一致。

最后,这个工具是开源 ( https://github.com/danrg/RGT-tool ) 的,并且部署在 http://repertorygridtool.com .

InfoQ:你希望从 RGT 用户那里获得什么样的反馈?

通常研究成果需要花费很长时间才会被工业界采用,有人说甚至要 10 到 15 年。获得用户的反馈对减少这个时间是非常有必要的。我期望两种类型的反馈:关于 RGT 和关于工具本身的。

所以,我希望听到 RGT 如何帮助架构师进行他们的决策。

因为这个工具是开源的。对这个工具的建议,Bug 的报告,以及贡献代码都是我关心的。我想围绕这个工具构建一个小的社区。

InfoQ:Grad Booch 曾经说过“傻瓜即使拥有工具还是傻瓜”。你如何确保架构师正确而有效率的方式使用 RGT?

关于更好的利用这个工具有三点。首先,确保你在正确的时间正确的地方使用 RGT:RGT 是一种利基(niche, 指范围狭窄)方法,不可能用于一切场景。第二,花一些时间学习 RGT。第三,从一些以前的架构决策开始,然后逐步在当前的决策和集体决策中使用。最后,分享你的经验,我很愿意提供帮助。

InfoQ:关于 RGT 和你的方法,你下一步有什么打算?

下一步打算增加一些基于关注点评估可选方案的实用功能,这会使评估比现在简单打分的方式更加精确。另外,我想实现关于风险管理的特性。其他的还有实现复合决策,这种决策的各种可选方案又由多种原子决策选择组合而成。复合决策可以对设计空间进行更彻底的探索,以确保那些有效的组合不会被忽略。

查看英文原文: University of Groningen Offers Repertory Grid Tool for Capturing Architecture Decisions


感谢崔康对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2013-01-24 01:192061

评论

发布
暂无评论
发现更多内容

数据脱敏是什么意思?有什么好处?

行云管家

数据库 数据安全 数据脱敏 数据库安全

"云智一体"全场景智能视频技术与应用解析白皮书下载申请

百度开发者中心

白皮书 云智一体 智能视频

了解JDBC层之QueryDSL

邱学喆

QueryDSL SQLQueryFactory

Chrome前端调试技巧分享

华为云数据库小助手

大前端 调试 GaussDB 华为云数据库

浪潮云洲发布标识解析数据网关产品

工业互联网

App 不想被“点名”,mPaaS 隐私合规检测为开发者护航数字生态建设

蚂蚁集团移动开发平台 mPaaS

移动开发 mPaaS 监管合规 隐私安全

开源应用中心|动手自建一个超高度自由的个人知识库,原来这么容易!

开源

联想TruScale服务定义IT服务新标准,助力中国企业全面抢滩智能化

科技范儿

百度智能云开物工业互联网平台解决方案亮相2021服贸会成果发布会

百度大脑

人工智能 服贸会

阿里后端优化这么恐怖?看完这20W字Java性能实战经验手册,最少P7

Java 阿里巴巴 面试 性能调优 金九银十

tcpdump 抓包与 scapy 解析(qbit)

qbit

udp TCP/IP tcpdump

MESI缓存一致性协议

Java 架构 面试 后端

阿里官方保姆级Java技术图谱发布!够学到春节了,赶紧收藏!

Java 面试 阿里 大厂 金九银十

守护油田安全,EMQ X 在石油石化危化品监测管理中的应用

EMQ映云科技

物联网平台 物联网 IoT 边云协同 emq

亚信科技AntDB数据库国产化进程加速,计费上云再下一城

亚信AntDB数据库

实践案例 9月日更

大公司运维监控怎么做?从哪些方面考虑?

行云管家

云计算 运维 运维监控 运维审计 数据监控

首场“说透数字化转型专题讲座”将于 9 月 15 日在天津举办

InfoQ 天津

一周信创舆情观察(8.30~9.5)

统小信uos

☕【Java技术指南】「并发编程专题」Fork/Join框架基本使用和原理探究(基础篇)

码界西柚

Java forkjoin forkjoinpool 9月日更

iOS 屏幕旋转的实践解析

ZEGO即构

ios 音视频 屏幕旋转

交易所刷量机器人定制开发案例(源码搭建)

量化系统19942438797

交易所 做市机器人 自动刷量机器人

让 Serverless 应用开发更简单,Serverless Devs 2.0 全新发布

Serverless Devs

开源 Serverless

C语言中动态内存是如何分配的?

华为云开发者联盟

数组 内存 动态内存 内存分配 C语音

Tapdata Real Time DaaS 技术详解 PART I :实时数据同步

tapdata

读了这篇SpringBoot底层原理让我在阿里成功涨薪40%,感谢

Java 编程 面试 涨薪 阿里

【墨天轮专访第四期】华为云GaussDB苏光牛:发挥生态优势,培养应用型DBA

墨天轮

数据库 华为云 GaussDB

会员业务基于Cloud KMS的数据安全应用

爱奇艺技术产品团队

数据安全法 Cloud KMS

【VueRouter 源码学习】第八篇 - $route、$router 与 router-link 组件的实现

Brave

源码 vue-router 9月日更

被面试官问懵:TCP 四次挥手收到乱序的 FIN 包会如何处理?

华为云开发者联盟

TCP 网络 报文 挥手 FIN

想要入职阿里P6?最少啃完这本500页Java并发多线程源码笔记

Java 编程 面试 多线程 阿里

前端技术概览

数据库 大数据 时序数据库 tsdb 数据智能

来自荷兰格罗宁根大学的架构决策捕捉工具RGT_架构_Michael Stal_InfoQ精选文章