【老猿说架构】系统架构设计思维

简介: 系统架构设计思维

大家好,我是老猿,今天继续专题【老猿说架构】,文章仅代表作者观点,如有不同观点论述欢迎拍砖交流。好,废话不说,直接进入主题。

上篇讲到系统架构设计核心是解决软件之熵带来的问题,那么架构设计前一定要对业务要有全面深入理解全局把握及未来发展评估,在此基础上进行抽象、分解、建模、构建设计,在我看来就是系统架构设计具备三种思维,具体详见下面讲解。

思维1:识别系统核心复杂点(软件之熵)

     系统的复杂度如何识别呢?那么首先我们必须全面准确理解业务当前和近期(一般1-2年)对系统容量指标的要求,也就是我们熟悉的容量指标:

高性能(高并发)

满足业务的增长

追求良好的用户体验

高可用(经常讲的N个9)

系统的服务稳定性和数据一致性

可扩展性

能够适应未来一定业务发展

规模

数据规模和未来数据增长速度带来的影响

业务功能规模不断膨胀的适应和扩展实现,即是降低架构腐化速度。

安全

各种应用安全漏洞、数据安全存储、传输和显示脱敏等

以上系统容量指标的要求越高系统实现的复杂度接越高,那么我们要根据业务当前和近期(一般1-2年)对系统容量指标的要求做出适用的系统架构设计,切忌过渡设计,比如一个文章发布系统,初期对系统容量的指标要求基本是适应多种类型文章发布和文章访问的速度,做好文章数据结构变化的数据字典支持及引入CDN、文章数据缓存实现基本就够了。

思维2:业务逻辑和系统控制逻辑有效分离

      上篇讲到软件系统架构就是系统的子系统、模块、组件的分解实现同时处理好他们协作运行关系,那么就要识别出系统实现的业务功能和非业务功能(即是系统控制逻辑)并做好他们的有效分离实现,这样做的好处就是方便管控系统复杂度带来的影响,比如微服务架构spring cloud在这方面设计是做得很好,如网关层一般担当非业务功能实现,比如统一路由、异常处理、权限校验和熔断降级、限流限速流控方面的处理,微服务之间的发现、调用的负载均衡及熔断降级都有对应的组件实现,同时给到对应服务治理组件的实现,比如服务调用的全链路追踪等,这样就很好地做到了业务逻辑和系统控制逻辑有效分离,让开发人员集中做好系统业务子系统或模块及组件分解和实现,从而有效地管控好软件复杂度带来的影响,方便支持实现系统的高性能、高并发、高可用、可扩展性。

思维3:传输、计算、存储的抽象

      任何系统动作实现都是输入、计算、存储和输出,那么系统架构设计最大的抽象就是设计好传输控制组件、业务计算组件分解与协作、数据存储的组件实现,也是对第二个视角做好全系统架构的抽象、分解和建模。


文/老猿,写代码写诗写职场的程序猿大叔,倾力原创简单实用的硬干货,转载此文请联系老猿

相关文章
|
1月前
|
Linux 调度
单片机面向对象思维的架构:时间轮片法
单片机面向对象思维的架构:时间轮片法
18 0
|
消息中间件 缓存 架构师
【老猿说架构】系统架构设计原则和步骤
【老猿说架构】系统架构设计原则和步骤
267 0
【老猿说架构】系统架构设计原则和步骤
|
9月前
|
设计模式 运维 架构师
一站到底!阿里新产架构进阶宝典限时开源,架构不止于思维
关于程序员如何成长这个问题在网上一直备受争论,可能有些人都会觉得Java程序员未来的路线无非就是︰一直往上爬,爬不动了就洗手不干了。目前的状态就是在公司不停地复制粘贴,再复制再粘贴的过程,基本上没机会去设计整个(部分)系统,也不会去设计数据库,要么就是系统就百八十人在用,也不考虑性能,代码堆完就OK了。每天的工作一样,基本上都在混日子,想跳槽跳出去工资也涨不了多少,年纪轻轻地就处于养老状态了。
|
11月前
|
存储 数据可视化 架构师
「方案架构」“解决方案架构”日常思维
「方案架构」“解决方案架构”日常思维
|
11月前
|
新零售 存储 数据安全/隐私保护
新零售SaaS架构:多租户系统架构设计(2)
新零售SaaS架构:多租户系统架构设计
616 0
|
11月前
|
存储 新零售 监控
新零售SaaS架构:多租户系统架构设计(1)
新零售SaaS架构:多租户系统架构设计
832 1
|
运维 Kubernetes 供应链
【老猿说架构】那些因素决定架构活动的成败
【老猿说架构】那些因素决定架构活动的成败
209 0
【老猿说架构】那些因素决定架构活动的成败
|
存储 设计模式 缓存
【老猿说架构】高并发高可用易扩展架构设计的套路
【老猿说架构】高并发高可用易扩展架构设计的套路
242 0
【老猿说架构】高并发高可用易扩展架构设计的套路
|
消息中间件 存储 设计模式
|
存储 运维 Cloud Native