我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何建立架构师的立体化思维?

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何建立架构师的立体化思维?

从程序员往架构师转型的路上,蔡学镛老师总结的“四维架构设计方法论”对我颇有帮助,让我对架构设计有了更立体化、系统化的认知,现将学习心得分享出来供需要的小伙伴参考。

这套方法论通过空间(X、Y、Z)三个维度及时间T维度将问题域解构成可以轻松应对的小方块,分而治之。同时,空间(X、Y、Z)三个维度联动,专门为单个维度解决不了的问题提供解决方案。时间 T 维度将问题分解到一个时间范围内,分步骤按节奏逐一解决。多维度、立体化、分层次、动态演进,这是我对这套方法论特点的总结。接下来,让我们进入这个四维的架构时空一探究竟!

如何建立架构师的立体化思维? 

图1 四维座标系统

前后端维度(X1 … X7

前后端维度被分解为交互、业务、领域、资源四大层,其中业务可以细分为应用X2、框架X3,领域可以细分为服务X4、核心X5,资源也可以细分为代理X6、数据X7,共分为七个层次。服务X4可以实现API,如果公开,就是开放接口,调用服务层的接口,通常需要授权。代理X6可以实现SPI,隔离耦合,避免核心X5 依赖特定的外部系统或数据库。每个层次做到高内聚,层与层之间做到低耦合。

如何建立架构师的立体化思维?

图2 X轴分层结构

在系统实现过程中,可以综合考虑现状,X2应用和X3框架可以不分拆,X4服务和X5核心可以不分拆,待后续时机成熟可以再重构分层,这样变更范围仅在内部。

表2 X轴七层架构模型及其定位

分层类型

分层名称

颜色

代号

分层定位

交互

界面层

X1

界面更像是用户的延伸,而非应用的延伸。界面可被视为用户代理。根据用户喜好、语言、平台(手机、电脑、平板等)开发各种用户界面。

业务

应用层

X2

一个应用可以有多个界面,根据市场需求,开发各种应用,并以接口的方式展现。

框架层

X3

将常用的应用流程设计成框架,后续开发同类型应用时,只要通过参数或者 DSL,就可以轻易订制应用,减少开发成本。框架也可以用接口的方式开放让外部调用。

领域

服务层

绿

X4

服务层针对领域对象进行操作,并提供弹性的调用接口。服务层接口通常数目不多,但每个接口通常参数相当多。服务层没有状态,也不做缓存。

核心层

X5

核心层反映领域模型,核心层的接口基本就是对此领域模型进行操作。建立领域模型,一方面帮助接口设计,另外一方面帮助数据存储设计,梳理出弹性的存储方式。

资源

代理层

X6

具备下列作用:数据代理,代表外部系统或数据库;缓存,为了效率或提高可用性(当外部系统掉线);数据模块,支持读写分离;转接或转发,转接到外部系统,转发到日志系统;数据备份系统(通过事件钩子);热备系统接入。

数据层

X7

数据是公司最重要的资产。根据数据的特性,数据库可以是:关系式数据库;列数据库;Associative DB;Key-Value;文件数据库;日志。

 

业务维度(Y1 ... Yn

从业务维度进行划分,按照业务类型对系统进行分类。业务系统的划分更多依赖业务领域的知识,这个维度设计最常用的方法论就是领域驱动设计DDD。

当Y轴的一个业务系统需要调用Y轴的另外一个业务系统时,兼顾效率和耦合,这套架构设计方法论给出了具体的架构原则:

  1. 当被调用的是公共系统时,那么调用将被视为内部调用,即服务可以直接调用服务。考虑到公共系统比较稳定,不会经常改变,直接调用可以减少调用环节,保障效率。
  2. 当被调用的是非公共系统时,那么调用将会被视为外部调用,即通过代理层去调用被调用系统的对外服务接口。这相当于把两个系统后台进行了串联,降低了系统之间的耦合,后续被调用系统发生变更,对调用系统的影响也可以藉由其代理层进行了隔离。

如何建立架构师的立体化思维?

图3 Y轴不同业务系统之间调用关系 


系统维度(Z1...Zn

该维度主要关注软件、容器、运行时、操作系统、虚拟机、到硬件等这些与业务无关系统的架构。Z轴的系统可以分别用于前端优化、应用优化、平台优化、资源优化等层面。

如何建立架构师的立体化思维?

图4 Z轴分层结构


时间维度(T1 … Tn

对于一个新产品来说,架构不是一次成型的,从初始到成熟要经过一个不断演进的过程。对于一个已有产品来说,架构的优化也是要结合实际情况分步骤实施。除了技术上的考虑之外,我们还需要考虑市场及投资等方面的情况。

通常,在研发的初期,产品本身的定位还不太清晰,需要快速地迭代投放市场获取先发优势,以及验证想法,不断地明确产品的定位。这个阶段产品需求变动非常频繁,许多架构的驱动因素尚未明确,如果过于关注架构,那产品推向市场就会遥遥无期。随着产品定位的逐步清晰,架构的驱动因素及约束条件都逐渐浮出水面,这个时候架构设计的重要性就显现出来了。另外,我们还需要根据投资预算来调整架构设计。如果投入比较充裕,那我们就可以投入更多的人力来提前将架构驱动因素研究清楚,甚至可以针对不确定的约束提供多套备选方案。

先分享到这里,后续我还会继续分享各个维度的架构设计心得,请感兴趣的小伙伴记得关注哦!原创不易,如果你觉得有价值,麻烦动动手指点个 「 」,老兵哥会更有动力。另外,我还会持续分享职业规划、应聘面试、技能提升、影响力打造等经验, 关注 「  IT老兵哥 」, 赋能程序人生

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何建立架构师的立体化思维?

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何建立架构师的立体化思维?

从程序员往架构师转型的路上,蔡学镛老师总结的“四维架构设计方法论”对我颇有帮助,让我对架构设计有了更立体化、系统化的认知,现将学习心得分享出来供需要的小伙伴参考。这套方法论通过空间(X、Y、Z)三个维度及时间T维度将问题域解构成可以轻松应对
2023-06-05

如何建立SEM数据分析思维

本篇内容主要讲解“如何建立SEM数据分析思维”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何建立SEM数据分析思维”吧!  发现问题  在账户推广中遇到的问题非常多、多到无法很多人都无法想象。
2023-06-10

全面教你如何建立数据分析的思维框架

这是一道分水岭,“我觉得”是一种直觉化经验化的思维,工作不可能处处依赖自己的直觉,公司发展更不可能依赖于此。数据证明则是数据分析的最直接体现,它依托于数据导向型的思维,而不是技巧,前者是指导,后者只是应用。编程学习网教育
全面教你如何建立数据分析的思维框架
2024-04-23

网站建立网页设计的时候要如何进行优化

小编给大家分享一下网站建立网页设计的时候要如何进行优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  第一、不可以过去的使用外链工具千万不要太过去迷恋那些外链工
2023-06-10

如何在MySQL中建立会计系统的表结构以满足不同的会计需求?

如何在MySQL中建立会计系统的表结构以满足不同的会计需求?随着数字化时代的到来,会计系统在企业管理中扮演着重要的角色。为了满足不同企业的会计需求,构建一个合理的数据库表结构非常重要。MySQL作为一个常用的数据库管理系统,提供了灵活的架构
如何在MySQL中建立会计系统的表结构以满足不同的会计需求?
2023-10-31

Teradata如何应用在数据湖和数据仓库一体化的架构中

在数据湖和数据仓库一体化的架构中,Teradata可以发挥重要作用。Teradata是一种集成式数据分析平台,可以处理大规模的数据,并提供高性能的数据处理和分析能力。在数据湖中,Teradata可以帮助用户将不同来源的数据整合到一个统一的
Teradata如何应用在数据湖和数据仓库一体化的架构中
2024-04-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录