肥宅钓鱼网
当前位置: 首页 钓鱼百科

怎么样绘制架构图(怎样画一张人见人爱的系统架构图)

时间:2023-06-11 作者: 小编 阅读量: 1 栏目名: 钓鱼百科

所以,设计IT系统架构图,第一步就是要完成合理的“抽象”。两者都想要了解系统的基本原理,不想面对一个黑盒产品,但是非开发者型客户通常不需要了解过多的技术细节,所以适合使用较高抽象水平的表达。

文/明道云创始人任向晖

在我们IT行业,经常要画系统架构图。这是和客户,上下游伙伴进行技术和商务沟通的有效工具。几乎任何一个复杂企业软件产品和方案都会把系统架构图作为商业表达的重点。在技术研讨会上,这些架构图往往是幻灯片的主角,不仅出现在现场屏幕上,还是现场观众举起手机拍照的重点对象。所以,一副精确且大气漂亮的系统架构图能够同时体现公司产品的架构能力和品牌形象。

IT架构图看起来总是高大上,复杂的系统有时候不知道从何着手,但只要掌握几个关键步骤,你就能够做出惊艳的成果来,让读者赏心悦目的同时,增强研读的兴趣。

一、从具象到抽象

架构图表达的就是事物的结构,大多数领域都可以用具象的方式来呈现,比如下图中的人体器官系统图就显得一目了然。但是IT行业几乎没有具象表达的可能性。不像人体器官系统的直观视觉表达那么有效。所以,设计IT系统架构图,第一步就是要完成合理的“抽象”。

1、恰当的颗粒度

抽象最重要的目标就是决定用什么样的颗粒度来列出事物,而不是巨细无遗。这完全取决于架构图的受众和想要表达的系统的规模。越是非技术受众,越要降低颗粒度,越是大型系统,也要降低颗粒度。虽然我们可以在一个架构图中表达事物的层次,但是平面空间总是有限,就像人体器官分布图没办法呈现细胞组织一个道理。

IT系统架构图的受众通常包括客户和技术伙伴。两者都想要了解系统的基本原理,不想面对一个黑盒产品,但是非开发者型客户通常不需要了解过多的技术细节,所以适合使用较高抽象水平的表达。而参与产品生态的开发者、合作伙伴则希望了解更详细的系统信息,拓扑结构,因此需要一个颗粒度更高的表达版本。这一版本通常出现在产品技术白皮书中。

举个操作系统的例子。如果要用一个架构图呈现Windows的系统架构,对普通用户只需要切入到系统内核、内存管理、文件系统、GUI、设备管理这样的大模块就行。但对于Windows应用开发者,则需要继续延伸到DLL库、注册表、API等技术细节。对于后者,实践中可能要拆分成若干个子系统的架构解析才行,因为要把所有的技术细节都放到一张图中并不友好。如果搞错了受众,用过度技术化的细节架构会让一般读者无所适从。

最简单的操作系统架构图,只有四个抽象对象

相比较,一个更加详细的macOS操作系统架构图

2、通用和规范的命名

确定了抽象层级,在架构图上就要列出需要表达的事物对象。因为缺乏具象的参照,所有的对象表达唯一途径就是文字标签,最多加上符号图标。这就要求制作者必须使用规范或约定俗成的事物命名,否则读者将无法理解。比如,上例中的操作系统架构图,File System绝对不能写成Doc System,因为只有前者是一个规范名称。

很多IT产品设计中会有自己的独特命名组件,甚至这些命名没有任何的语义元素。这些命名在架构图中出现必须要附加实际含义的说明,否则没有读者会知道“海豚系统“是什么意思。当然IT行业中也会出现强势垄断产品,以自己的独特命名确定行业标准,以至于你不知道都不好意思,这种情况当然另当别论。

当使用图标和符号来表达事物对象时,要注意选择规范和识别性强的图形。在一些非常专业的领域,比如电子电气架构图,甚至有对各种组件规范的标准定义。即使有含义准确的符号图标,依然建议制作时附加上文本标签,可以让架构图的读者更明晰地理解。相反,没有图形,只有文字的架构图是完全可以接受的。

得益于该行业突出的模块化程度,电子电路也有抽象表达的架构图,但它有严谨的绘制规范。

3、明确抽象对象之间的关系

在进入正式的绘制之前,我们还要确定抽象对象之间的关系。这将决定我们用什么视觉形式来准确地表达架构。

在抽象系统架构中,各种对象之间的关系只有三种:包含、并列和联结。比如操作系统包含用户模式和内核模式,用户模式和内核模式是并列的,客户端和服务器是通过TCP/IP协议连接(联结)的。无论系统多么庞大和复杂,对象和对象之间的关系就这么几种。而且,在平面空间中,无论怎么演绎,也只能有效地表达这些有限的关系类型。

你只需要稍稍瞥一眼下图,就知道各个方块所代表的组件彼此之间的关系了。看罢这个参考,我们就可以开始动手绘制了。

二、确定架构图形态1、三种基本形态

鉴于抽象对象之间有限的关系种类,架构图无非有三种形态:

分叉模式(Branching Model),表达事物的分支

网络模式(Network Model),表达事物的联结

通过空间组合,组合以上两种模式

所以,不必担心要表达的系统有多么复杂。只要认知到系统对象之间的内在关系性质,就不难选择一个基本形态来表达。如果空间允许,也完全可以综合运用分叉和网络一体化表达更完整的系统。

分叉模式

网络模式

2、确定边界

架构图既然表达的是一个系统,那么这个系统必然有一个明确的边界。计算机网络的边界是与上一级网络的连接网关,一个SaaS软件的边界是主体应用、其依赖的开源组件和网络服务。确定边界后的系统才能盘点内部所包含的组件对象层次和数量。依据第一步所介绍的抽象过程,我们根据受众需要,决定最终在画面上布局那些对象。一般而言,一个系统架构图不宜超过30-40个对象,超出这个限制则可能要考虑提高抽象层次;反过来,如果一个架构图只包含寥寥数个对象,那么我们也犯不着劳累追求架构图的高要求,转而用一些简单的框图就能够搞定,这时候,我们应该降低抽象层次,以反映出更具体和详细的架构信息。

超出这个既定边界的对象理论上无需绘制,但有时候我们为了表达与外部系统的连接关系,会用次要色彩在边界线外绘制部分系统边界外的对象。这有点像某个行政区的地图中会把连接其他区域的交通线上标上“通往...”。

3、确定主次

假设一个系统包含10个子系统,如果往下钻取一级,就有可能要表达上百个对象。这时候如果轻重不分,则可能让最终的产出过于繁复。我们可以依据策略的需要进行选择,只分支展开系统的一部分,而让其他部分粗略表达。不必要的细节展现过多,反而让读者无法识别出重点。因为每一张架构图都有明确的沟通目标和上下文,这样主次有别的表达不仅是合理的,而且很多时候是必要的。

4、确定空间位置

空间位置是架构图设计的关键。我们要按照易于理解的逻辑关系,把抽象对象放到平面上的合理位置。读者的视觉焦点就可以被空间关系有效引导,从而更直观地理解系统结构和原理。

在确定空间位置时,根据不同的架构图基本形态,有几个重要准则:

(1)分叉模式下,要注意均衡利用空间,避免画面一部分过度稀疏,一部分过度稠密。为了实现这一点,需要借助矩形框、连接分叉线的帮助。如果遇到了实在窘迫的空间限制,也可以利用Call-out的局部放大设计来利用独立的空间详解一个特定模块。

(2)分叉模式下,依然要关注逻辑次序。在树状分叉下,虽然每个分支的地位都是均等的,但是并不意味着可以随便决定次序。设计者依然可以根据同级别对象的主次关系、先后关系来决定排序。

(3)网络模式下,根据被联结组件的性质决定南北向。在IT架构设计中,一般把底层的基础技术组件定义为北向(North Bound),放在架构图的下方,把高层级的应用组件定义为南向(South Bound),放在架构图的上方。把中间的各个技术组件依照高低位性质依序排列联结。这就是我们经常看到的分层技术架构图。

典型的分层技术架构图

当然,南北向也不是绝对的上下结构。只要条理清晰,左右结构也同样可以表达这些递进的层次。例如下图:

(4)网络模式下,可以将具备联结关系的对象放在彼此邻近的位置上,以方便创建清晰的连接线。比如下图,在同一级别的层次上,可能存在彼此需要联结的组件。这时候,是放在左边,中间,还是右边就有一定的讲究了,否则就无法绘制出简洁的连线。

三、视觉设计

最后一部分,我提供一些有用的视觉设计技巧,它可以帮助你绘制出更美观的架构图。

1、制定统一的设计范式

在抽象架构图中,会充满组件框和连接线。无论使用何种绘图工具,先要定义出标准的图形样式、色彩、文本标签的字体、字号、连接线样式等。在真个架构图中,应该依据这些定义好的基本样式来重复对象,而不是想到哪里,画到哪里。很多架构图看起来充满了完全不同的组件样式,看起来凌乱不堪,就是因为缺乏了这个范式的约束。像下面这张架构图,制作者显然是随意在应用色彩和特效填充。

架构图上的同性质组件只能使用单一的图形样式,字体、字号和粗细都要统一,影响观感一致性的还包括字距、文本框边距(margin)、文本框间距(padding)、文本对齐模式等细节。这些样式属性,稍微有一些不一样,放到一张架构图中就会一眼看出来,非常不舒服。

原则上,我们应该最少的样式差异,不要使用过多数量的色彩,不要为了区别事物,把什么属性都重新定义一边。两类事物之间,靠色彩能区别,靠标签字号也能区别,甚至仅仅靠色彩明度就能区别,不需要同时变化两个属性。

2、使用图形符号辅助表达

利用计算机领域约定俗成的符号、专有图标或三维图形来增强架构图设计,可以让读者更轻松地阅读架构图。而且,精致的画面可以给读者传递系统的精密度和高质量感受。

用具象物缩略图来表达系统组件

用三维图形来表达组件层次

3、使用附注、旁注来平衡空间

在技术性较强的架构图中,有时候我们必须向读者提供一些重要的技术细节,但是架构图的空间可能不允许我们这么做。此时,可以使用编号附注或者Call-out连线的旁注来实现。

使用附注来说明系统组件,一般在有具象特征的架构图中使用


最后,我送上明道云的系统架构图。它设计简洁,充分使用图标符号来辅助读者阅读,很直观地说明了一个现代的零代码APaaS产品的技术实现、运行环境和集成方法。仅为了这个架构图,我们需要产品、研发和市场营销团队的通力协作,因为很少有设计师能够完全懂得复杂的云原生架构,也很少有架构师和工程师能够掌握必要的商业美学。

下载高清PDF

    推荐阅读
  • 藜麦孕妇可以吃不(孕妇可以吃藜麦粉吗)

    孕妇在食用藜麦就不会出现这种现象了,并且产后的妈妈使用藜麦,还可以达到减肥塑身的效果。此外,藜麦的含铁量是很高的,孕妇缺铁会出现心慌气短、头晕乏力,还会导致胎儿宫内缺氧,导致智力发育障碍,所以说补铁对于孕妇来说是很重要的。藜麦还可以解决孕期孕妇的便秘问题。

  • 正常走路可以减肥吗(正常走路可不可以减肥)

    走路减肥既健康又安全,而且没有太多的副作用,相对于服用减肥药或者是通过节食的方法来进行减肥,可能走路减肥更应该考虑,这样可以减少一些药物对身体的伤害。另外走路能够有效地消耗人体内的卡路里,减少体内脂肪的堆积,有较好的瘦身作用。因此现在不少男女老少都喜欢走路,想要达到减肥的目的,想减肥的人士在下班后可步行回家,另外在饭后的两小时步行减肥效果可能更佳,这个时候步行可以消耗体内的脂肪,更有利于瘦身减肥。

  • 大秦赋华阳夫人饰演者(大秦赋华阳夫人饰演者简单介绍)

    大秦赋华阳夫人饰演者大秦赋华阳夫人的扮演者是邬君梅。邬君梅,女,1966年2月5日生于中国上海,美籍华裔电影演员,毕业于上海市西中学。1990年成为美国独立精神奖获得者和美国演员工会会员及奥斯卡终身评委,同年被美国《人物》杂志评选为“世界最美50人之一”。1996年12月18日,与美籍导演奥斯卡在美国拉斯维加斯注册成婚。

  • 手机无锁什么意思(二手手机无锁什么意思)

    手机无锁的意思为在不越狱的条件下,能够使用任意的运营商的卡,也就是指我们能够在国内使用联通、移动以及电信的号码。且无锁的手机不受地区的限制,能够在任意的一个国家使用,还能够随意升级固件并且不用考虑信号的破解问题。

  • 干眼如何做按摩(日常如何护理)

    如果睑板腺堵塞的,按摩之前可以用热毛巾热敷眼睛。干眼症是可以通过改变生活与作息习惯和使用眼药水来改善和治疗。第一点是,尽最大可能每天少打手机,以减少眼睛损伤。另外,多吃水果和蔬菜来补充体内的维生素C,避免刺激食物,不要吃口味较辣的食物。规律的上班和休息习惯以及良好的生活与作息习惯对恢复也非常重要。控制您的情绪,注意休养,饮食卫生。

  • 于都印象银坑客家文化(于都传统文化之)

    忌孕妇踩踏牛、马绳,因牛、马皆怀胎12月而产,孕妇踩踏牛、马绳,将引起难产。忌孕妇搬重物、攀高,忌拍打孕妇肩膀,以免流产。忌孕妇参加丧事,尤其忌孕妇摸棺木或观看入殓、封棺,否则犯煞气。忌家中的“读书人”频繁出入“月房”,否则前程受阻。婴儿出生三天之内宜保密,以提防“阴生鬼”作恶。忌给婴儿留胎毛,满月前需剃胎毛。忌婴幼儿衣物过夜不收,据说夜间多“鬼鸟”,恐污衣物,使婴幼儿易患疾病。

  • 对学生表示激励的句子(有什么激励学生的句子)

    对学生表示激励的句子向前吧,荡起生命之舟,不必依恋和信泊,破浪的船自会一路开放常新的花朵。如果为了安全而不和大海在一起,船就失去了存在的意义。一时的挫折往往能够透过不屈的搏击,变成学问及见识。人若勇敢就是自己最好的朋友。要想成为强乾,决不能绕过挡道的荆棘也不能回避风雨的冲刷。天赋是埋藏在矿里的黄金,才能是挖掘矿藏的矿工。人之所以能,是相信能。

  • inxni导航扫地机器人 智能导航扫地机器人

    inxni以内导航扫地机器人X533的外观设计颇有特色,跳出了传统扫地机器人的无趣外观,整体造型有如轮胎,据称其灵感来自飞机涡轮的设计和跑车轮胎的外围造型,象征能自动驾驶的扫地机器人。通过这套AICU系统,inxni以内导航扫地机器人X533就能够生成2D地图,并根据家庭面积划分区域,且依据家居环境的变化实时更新地图,智能识别避开障碍物,从而进行清扫。

  • 梦魇的e不能打断吗(梦魇的e能不能打断)

    以下内容希望对你有帮助!和妖姬差不多,妖姬可以先用个E然后R,都不会互相打断,妖姬的E和梦魇的E都一样,都是必须释放了然后跟着人跑,一段时间后,就起到了控制效果。梦魇大招好像是不会受控制技能限制的。如果不受控制那就不能打断。e只要放出来除非走出施法范围,否则无法被打断。施法成功瞬间可以被女妖,或者英雄的某些技能躲避,或抵消。

  • 手机怎么查看电脑共享(手机怎么查看电脑共享网络)

    4、在手机的软件商店里下载安装ES文件浏览器,下载安装完毕后点击打开ES文件浏览器,在弹出的ES文件浏览器的首页点击左上方的菜单选择按钮,此时在左侧会弹出菜单选择菜单页面,点击网络菜单栏里的局域网。