【架构笔记1】剃刀思维-如无必要,勿增实体

news2025/1/24 10:58:07

欢迎来到文思源想的架构空间,前段时间博主做了一个工作经历复盘,10年开发路,走了不少弯路,也算积累了不少软件开发、架构设计的经验和心得,确实有必要好好盘一盘,作为个人的总结,同时也留给有缘读过的人,带给一丝启发或者少走一点坑,都是好事。于是有了这个文思架构笔记这个专题的想法,未来会陆陆续续梳理一些自己总结的东西和正在发生的事情,作为留存,也作为纪念。今天是第一篇——关于剃刀思维!

“如无必要,勿增实体” ,这句话来自奥卡姆剃刀原理的核心说明,针对云服务架构它也是非常必要。老子说大道至简,亚里士多德说自然界选择最短的道路,产品交互设计也有个理念叫less is more -- 少即是多。它不只是告诉人们要做减法,而是更多去思考我们实现功能外引入新的复杂度和问题,充分考虑和权衡。

在云服务架构演进中我们看到了许多演进共同的现象,为了多活我们引入了多活控制器,为了一个新增业务避免老功能受到影响,采用新增服务的方式隔离变化,为了调用尽量少的改动,我们将一个请求扩充到五六跳甚至更多。但是做法却同时也带了一些新的影响:

  • 首先服务调用链路更长了,这引入了更高的服务治理复杂度,我们不再是简单几跳解决一个请求,而是更多的中转也带了更多定位问题的复杂性,功能实现或许改动小了,但是未来压测、定位复杂问题更多了。
  • 其次引入新服务和模块,拆分微服务,更多的其实应该考虑的是业务的解耦,功能的复用,而不是站在小组的角度,考虑什么好做把几个功能聚合在一起,微服务架构设计虽然必然走向康威定律的方向(组织结构决定代码架构),但是实际上是需要有人做好评审和管控的。新增服务并不一定是好事,这个事情是需要评审和确定的,或者做一做减法,常常问一些新的问题:
    • 如果不要新增,是否能完成功能;
    • 如果新增服务带来哪些运维架构、安全、服务治理的隐患;
    • 是否还有其他更好的解决思路。

接着还有多活这个话题,通常多活在云服务架构里面有多种拆分方式,集群方案和多活控制器,当然采用上游负载均衡hash或者一致性hash找到下游服务的方式,这无疑是最常用的解决思路,但是他的问题也同样多:

  • 服务实体增多,部署复杂度、部署规格要求逐步放大,以前可能一个服务搞定的事情现在可能需要两个或者三个,这里是实打实的成本上升,私有云环境下以前可以四五十核搞定一个环境,而如今不下数百核一个最小系统都不能完备。诚然我们功能在增多、业务在复杂,但是我们每套云的用户数、规模并没有增大到数量翻倍的情况,这里的问题就是引入实体,但是没有做减法,没有定期回顾,看看哪里不合理。
  • 服务发现、服务间通信问题变得更加紧密,定位问题也成为了一个难点,再加上某些开源软件在调用链上的特殊性,导致治理和灰度成为了很棘手的问题。

最后我想到的则是设计和建模中的抽象,通常通过业务场景分析、用户动作行为拆解,我们会在概要设计中产生许多概念,但是落地的时候实际上是需要区分什么是视图层什么是核心层模型的,把变化留在视图层,而核心层模型的定义,我认为是要经过头脑风暴和反复核对的:

  • 把多余属性拆解到极致,去除掉一切冗余字段
  • 反思如何把业务用几句话说清楚,弄清楚关键模型和关键动作,然后还能看到未来的变化,以及未来我们怎么应对变化

虽然他们不全是领域驱动设计,但是也包含了领域驱动的一些思想。分析业务场景时候由少到多,遍历细节,建模归纳时候由多到少,用核心模型、动作,充分裁剪,最后通过考虑特殊情况,补充场景。最后的最后就是问一问能不能少一些实体,少一些不一样的接口,能否复用。

总之,接口、模型、字段、调用、服务、业务他们都是所谓的实体,如无必要勿增实体,我们设计时候就需要考虑这些实体存在的必要性,同时反思是否会带来影响其他必要实体的问题。功能实现简单性只是一个新增的理由,我们更多想想未来治理的代码,部署的复杂性,额外新增的机器和研发消耗更多的精力,以及冗余引起的争议和误会。我们不仅要实现功能,还需考虑业务的解耦,更要考虑实体的熵增。人熵增需要断舍离,软件系统熵增则需要重构,盘点、分析、归纳合并、设计、重构,这个事情是需要持续进行,是需要自上而下倡导,最终最下而上显现。

当然剃刀思维还有一个关键,就是我们有他,但是最好不需要它当一个不需要的实体存在,这个实体就会开始证明自己存在的必要,其他原来必要存在的实体也会因为他的存在而容易自发建立一套与它有关的新协作或者新习惯。老业务会通过新部门形成砍不掉的冗余流程,豆浆机也会在你买菜时候提醒你多买一些吃不完的豆子,这个时候在用剃刀就很难了,剃了就会很疼很受伤,然后就需要权衡有了犹豫。勿增实体而不是剃掉实体,是因为剃刀思维的关键是一开始就找到这些不需要的实体,防患于未然,所以需求评审、架构设计、模型设计、调用流程设计都需要有这样的思考和审核,从一开始就找到这些没有必要存在的实体。

剃刀的真意在于止“繁”存"简" ----心存一刀,只留必要,心中有刀无需用刀,才是最好的状态,或许这是必字的另一种解释,也是我们设计架构的一个需要重视的要诀。

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

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

相关文章

2024.2.29 模拟实现 RabbitMQ —— 项目展示

目录 项目介绍 核心功能 核心技术 演示直接交换机 演示扇出交换机 演示主题交换机 项目介绍 此处我们模拟 RabbitMQ 实现了一个消息队列服务器 核心功能 提供了 虚拟主机、交换机、队列、绑定、消息 概念的管理九大核心 API 创建队列、销毁队列、创建交换机、销毁交换机、…

【Go的函数】

函数 函数的引入函数细节祥讲包的引入包的细节详讲init函数匿名函数闭包defer关键字系统函数字符串相关函数日期和时间相关函数内置函数 函数的引入 【1】为什么要使用函数: 提高代码的复用,减少代码的冗余,代码的维护性也提高了 【2】函数…

如何多环境切换?如何在微服务配置多环境?

问题本质: nacos配置中心的配置是如何被项目读取到的?(nacos的配置中心和项目是如何联系的?) 注意:nacos有配置管理和服务管理,别弄混。自动注册的是服务管理!!! 1. 如何注册到nacos服务管理中心…

《YOLOv9:从入门到实战》报错解决 专栏答疑

前言:Hello大家好,我是小哥谈。《YOLOv9:从入门到实战》专栏上线后,部分同学在学习过程中提出了一些问题,笔者相信这些问题其他同学也有可能遇到。为了让大家可以更好地学习本专栏内容,笔者特意推出了该篇专…

阿里云服务器多少钱?免费的不要钱!

注册阿里云账号,免费领云服务器,最高领取4台云服务器,每月750小时,3个月免费试用时长,可快速搭建网站/小程序,部署开发环境,开发多种企业应用。阿里云服务器网aliyunfuwuqi.com分享阿里云服务器…

【wu-acw-client 使用】案例

wu-acw-client 使用 项目介绍,使用acw-client,创建对应Java项目的增删改查(ORM:Lazy ORM、mybatis),项目模块架构:mvc、feign、ddd 演示项目环境:idea 、mac、mysql、jdk17 spring …

【C++进阶】深入了解继承机制

目录 前言 1. 继承的概念 2. 继承的定义 3. 继承中基类与派生类的赋值转换 4. 继承中的作用域 5. 派生类的默认成员函数 6. 继承与友元、静态成员 7. 多继承与菱形继承 7.1 如何解决 前言 继承是面向对象编程中的一个重要概念,也是面向对象编程语言中普遍存在的特…

Python爬虫中的单线程、多线程问题(文末送书)

前言 在使用爬虫爬取数据的时候,当需要爬取的数据量比较大,且急需很快获取到数据的时候,可以考虑将单线程的爬虫写成多线程的爬虫。下面来学习一些它的基础知识和代码编写方法。 一、进程和线程 进程可以理解为是正在运行的程序的实例。进…

实验室储样瓶耐强酸强碱PFA材质试剂瓶适用新材料半导体

PFA,全名可溶性聚四氟乙烯,试剂瓶又叫取样瓶、样品瓶、广口瓶、储样瓶等。主要用于痕量分析、同位素分析等实验室,广泛应用于新兴的半导体、新材料、多晶硅、硅材、微电子等行业。 规格参考:30ml、60ml、100ml、125ml、250ml、30…

QT项目打包

十、项目打包 设置图标 以下是个项目设置图标的 操作步骤 设计或下载一个图标图片(推荐分辨率6464及其以上,256256及其以下)。转换为.ico格式,转换可以使用下面的网站。 Convertio — 文件转换器 PNG转ICO, 在线转换器 - 转换视频…

国家开放大学 新学期 电大搜题助力学子们取得理想成绩

尊敬的读者朋友们,您是否曾经遇到过在学习中遇到困难,却找不到合适的学习资源和答案的尴尬处境?您是否经历过为了解决学习难题四处奔波而导致时间和精力的浪费?如果您曾经面临这样的困扰,那么您一定不能错过今天为您推…

三、系统知识笔记-计算机系统基础知识

一、计算机系统概述 计算机系统是指用于数据管理的计算机硬件、软件及网络组成的系统。 它是按人的要求接收和存储信息,自动进行数据处理和计算,并输出结果信息的机器系统。 冯诺依曼体系计算机结构: 1.1计算机硬件组成 冯诺依曼计算机结…

中间件-Nginx漏洞整改(限制IP访问隐藏nginx版本信息)

中间件-Nginx漏洞整改(限制IP访问&隐藏nginx版本信息) 一、限制IP访问1.1 配置Nginx的ACL1.2 重载Nginx配置1.3 验证结果 二、隐藏nginx版本信息2.1 打开Nginx配置文件2.2 隐藏Nginx版本信息2.3 保存并重新加载Nginx配置2.4 验证结果2.5 验证隐藏版本…

LeetCode刷题---查询结果的质量和占比

思路&#xff1a; 首先按照query_name进行分组操作 对组内的rating/position的值求平均值得到quality 对组内的rating的值使用IF函数进行判断&#xff0c;如果rating<3则将其标识为1&#xff0c;如果rating>3,则将其标识为0&#xff0c;通过次方法可以找出组内rating的值…

MNIST数据集下载(自动下载)

&#x1f4da;**MNIST数据集下载(自动下载)**&#x1f4da; &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程 &#x1f448; 希望得到您的…

微信小程序的医院体检预约管理系统springboot+uniapp+python

本系统设计的目的是建立一个简化信息管理工作、便于操作的体检导引平台。共有以下四个模块&#xff1a; uni-app框架&#xff1a;使用Vue.js开发跨平台应用的前端框架&#xff0c;编写一套代码&#xff0c;可编译到Android、小程序等平台。 语言&#xff1a;pythonjavanode.js…

【UE 材质】冰冻效果

效果 步骤 1. 打开“Quixel Bridge” 下载冰的纹理 2. 新建一个材质&#xff0c;这里命名为“M_Frozen” 打开“M_Frozen”&#xff0c;添加如下节点&#xff0c;此时我们可以通过控制参数“偏移”来改变边界的偏移 此时预览效果如下 如果增加参数“偏移”的默认值效果如下 3.…

在 Android 运行 GNU/Linux 二进制程序 (proot)

在 GNU/Linux 系统上运行 Android 应用比较容易 (比如 waydroid), 但是反过来就很麻烦了. Android 虽然也使用 Linux 内核 (kernel), 但是系统环境和一般的 GNU/Linux 系统 (比如 ArchLinux, Debian, Ubuntu, Fedora, NixOS 等) 具有不可忽略的显著差异, 所以为 GNU/Linux 编译…

泽攸科技JS系列高精度台阶仪在半导体领域的应用

泽攸科技JS系列高精度台阶仪是一款先进的自主研发的国产台阶仪&#xff0c;采用了先进的扫描探针技术。通过扫描探针在样品表面上进行微观测量&#xff0c;台阶仪能够准确获取表面形貌信息。其工作原理基于探针与样品表面的相互作用力&#xff0c;通过测量探针的微小位移&#…

[论文笔记] Mistral论文解读

https://arxiv.org/pdf/2310.06825.pdf GQA: 1、加快推理速度 2、减小内存需求 3、允许更大的batch 4、更高的吞吐量 SWA&#xff1a; 1、较低的计算成本 更有效的处理 较长的序列。 2、感受野更符合常理。不再是全局感受野&#xff0c;而是只和前4096个进行语义融合。…