你真不敢说精通微服务架构深度解析:微服务采用前提康威定律吗?-程序员宅基地

技术标签: 云原生  程序员  微服务  架构  

微服务架构倾向于组织架构围绕业务领域边界进行划分,这种协作方式是比较理想的。通过构建与业务架构一致的团队组织,实现每个独立的团队都可以为自己负责的业务和技术负责。这种组织结构的好处在于:需要升级或者变更服务时,各角色成员可以在团队内部进行高效沟通,有利于达成共识和高效协作。只有外部服务之间的接口需要变更时才需要跨部门沟通,如果前期在服务之间的交互上定义了良好的接口,则接口变更的概率并不大,即使接口模式有变更,也可以通过一定的设计模式和规范来协作解决。

组织划分的最终目标是实现每个团队组织都有清晰的边界和职责。通过组织的划分,形成高内聚、可复用的业务形态,聚焦的技术架构有利于功能模块的沉淀积累和迭代演进。把不属于自己职责的业务或者技术,尽量从自己的服务中剔除,通过组织协作的方式实现低耦合,避免职责重复带来的工作重复和效能损失。

康威定律从本质上说明了组织结构对系统架构的影响,强调系统设计与组织结构的不一致导致的危险和协作问题。当我们的系统规模开始扩大时,这种协作问题将会对微服务系统的业务响应、需求变更、质量保证等方面产生更加深刻的影响。

你真不敢说精通微服务架构深度解析:微服务采用前提康威定律吗?

沟通效率问题

======

《人月神话》中说:一项工作在估算和安排中使用工作单位“人月”来计算成本。这里需要说明的是“成本”虽然可以根据开发产品的人数和时间确定,但是工作的进度却不一定,因为使用“人月”来评估一项工作的规模是存在欺骗性的,人数和时间在一定程度上是无法互换的,一个原因就是忽略了最重要的因素:人员之间的沟通成本。

软件开发本质上是一项系统工作,需要团队成员密切配合才能完成,是错综复杂关系下的一种密集脑力活动实践。沟通、交流的工作量非常大,它很快会消耗任务分解所节省下来的个人时间。而添加更多的人手,实际上增加了沟通的成本,降低了个人的工作效率。

沟通效率往往会受到组织结构的影响。按照康威定律,我们的组织结构应该与我们的应用架构保持一致,最早践行微服务架构的亚马逊和Netflix可以说是执行这条原则的典范,通过小团队的构建提升了沟通的效率。

例如,在Netflix,存在很多小而独立的团队,这些独立的团队创建的服务也是彼此独立的,这最小化了沟通成本,带来了效率的提升。这样,软件架构也可以得到快速迭代和演进。

人与人的沟通是非常复杂的,一个人的沟通精力是有限的,所以当问题太复杂,需要很多人协调解决的时候,我们需要拆分组织来提高沟通效率。团队的组织方式从某种程度上决定了他们设计的系统架构,而高效的沟通不仅有利于为业务人员提供即时的反馈,也能够以最小的代价达成共识,实现降本增效。

组织的演进

=====

在实施微服务初期,管理者一般将大部分精力集中在满足业务和服务的功能性诉求上。很多小型团队在不需要太多精力投入的情况下,通过开源软件搭建注册中心、API网关、容器等微服务基础设施,就可以完成基本的微服务管理功能。

然而,随着业务的快速增长和微服务规模的扩大,以及系统复杂性的上升,维护这样一套基础设施会给业务团队带来额外的压力,在关注业务自身功能的同时,管理者还要将精力消耗在非功能需求和以技术为导向的微服务支撑平台上。这个时候,管理者往往低估了微服务架构的复杂性,以及伴随微服务发展的高可用、高并发、可扩展性等技术诉求。管理者需要重新审视组织结构是否适应公司整体技术架构的发展。微服务架构从某种程度上说是一个CTO工程。

我们需要业务团队更加聚焦于自己的核心业务能力,正如Supercell公司,它是一家典型的以小团队模式进行游戏开发的公司,一般来说两个员工或者5个员工,最多不超过7个员工组成独立的开发团队,称为Cell(细胞),这也是公司名字Supercell(超级细胞)的由来。该公司可以通过这种小团队,快速试错,来检验游戏是否被用户接受和受欢迎程度,实现了小步快跑。
然而Supercell的小团队背后是有一个大的平台组织来做支撑的。
我们说微服务架构同样需要具备平台化的可复用和支撑能力,平台化的思维和支撑能力不仅仅意味着需要建设以技术为导向的微服务架构、自动化发布平台、容器基础设施,还需要组织结构能够根据业务形态进行持续的演进。微服务架构如果想规模化、成体系化发展,甚至像亚马逊和Neftlix这样的公司一样对外输出技术能力,还需要公司做统一的战略规划,需要有以技术为主的平台团队,以及以业务为导向的中台团队。微服务架构的体系化仅从技术维度进行是难以奏效的,最终技术架构一定会受到组织结构的影响,组织结构的演进对企业的竞争力和非线性的增长至关重要。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

这份文档从构建一个键值数据库的关键架构入手,不仅带你建立起全局观,还帮你迅速抓住核心主线。除此之外,还会具体讲解数据结构、线程模型、网络框架、持久化、主从同步和切片集群等,帮你搞懂底层原理。相信这对于所有层次的Redis使用者都是一份非常完美的教程了。

image

整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~

你的支持,我的动力;祝各位前程似锦,offer不断!!!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
全套讲解视频、实战项目源码讲义》点击传送门即可获取!**

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/2401_84048398/article/details/137973483

智能推荐

AutoCAD Civil 3D-横断面-创建横断面、横断面图及采样线的编辑(断面法工程量计算)_civil3d 横断面 长度标签-程序员宅基地

文章浏览阅读9.2k次,点赞2次,收藏10次。AutoCAD Civil 3D的功能很强大,强大到很多功能事实上是我们不需要的。对于仅需要使用断面法计算工程量的童鞋来说,需要掌握的知识点主要有:1、展点(参见相关与点有关的博文);2、成地形(创建曲面,曲面有关的博文第一节,后面的有关样式、曲面操作属于进修内容,计算方量可先忽略);3、剖断横断面(本文内容)出方量表,OK,搞定,Let's go!在前面的道路模型的章节中..._civil3d 横断面 长度标签

Flutter初体验-03-逻辑端_flutter dart_ping-程序员宅基地

文章浏览阅读194次。采用flutter开发的网络设备扫描工具,逻辑端_flutter dart_ping

WEB下使用的OFFICE控件介绍_weboffice 在第几行-程序员宅基地

文章浏览阅读2.4k次。首先来个名词解释,Office网络文档控件,就是在网页中编辑office文档的控件(前提是browser已经安装OFFICE)。最近一个项目需要用到这个玩意,经过不泄努力的百度和GOOLE,发现Office网络文档控件资源,目前国产的有以下几款:一、iWebOffice2006江西金格网络科技有限责任公司http://www.goldgrid.com/DownLoad/index._weboffice 在第几行

大数据FLINK实时数仓项目实战-程序员宅基地

文章浏览阅读6.2k次,点赞7次,收藏41次。普通的实时计算优先考虑时效性,所以从数据源采集经过实时计算直接得到结果。如此做时效性更好,但是弊端是由于计算过程中的中间结果没有沉淀下来,所以当面对大量实时需求的时候,计算的复用性较差,开发成本随着需求增加直线上升。实时数仓基于一定的数据仓库理念,对数据处理流程进行规划、分层,目的是提高数据的复用性。 原始数据,日志和业务数据 。根据数据对象为单位进行分流,比如订单、页面访问等等。维度数据。对于部分数据对象进行进一步加工,比如独立访问、跳出行为,也可以和维度进行关联,形成宽表,依旧是明细数据。根据某个主题将_flink实时数仓项目实战

Python安装tensorflow_collecting oauthlib>=3.0.0 (from requests-oauthlib-程序员宅基地

文章浏览阅读4.2k次。Python2 Python3 安装 TensorFlow国内镜像源报错GoogleAPI源安装pip3 install https://storage.googleapis.com/tensorflow/mac/cpu/tensorflow-0.12.0-py3-none-any.whl _collecting oauthlib>=3.0.0 (from requests-oauthlib>=0.7.0->google-auth-oauth

java 如何解决用户请求重复提交问题?_java限制同一用户连续请求怎么解决-程序员宅基地

文章浏览阅读1.9k次,点赞8次,收藏17次。简化的模拟代码如下(基于 Spring Boot):import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;@RequestMapping("/user")@RestControllerpublic class UserController { /** * 被重复请求的方法 ..._java限制同一用户连续请求怎么解决

随便推点

C++构造和析构_c++ 析构比构造多-程序员宅基地

文章浏览阅读185次。构造函数构造函数的作用是给类中的数据成员初始化,在一个类对象产生的时候自动调用,构造函数分为带参构造、无参构造。带参、无参构造他俩唯一的区别就是一个有参数,一个没参数,视实际情况使用class CMyC{ int a; float b; char ch[10];public: CMyC(int a,float b,char *ch);//带参 CMyC(..._c++ 析构比构造多

树莓派基础设置-显示中文和添加中文输入法_树莓派输入法图标不显示-程序员宅基地

文章浏览阅读2k次。显示中文和添加中文输入法因为树莓派默认是采用英文字库的,而且系统里没有预装中文,所以你即使在locale中改成中文,也不会显示中文,只会显示一堆方块。因此我们需要手动来安装中文字库。干货:1.打开终端输入以下命令安装中文字库sudo apt-get install ttf-way-zenhei安装过程中如果碰到(y/n)都选择y2.安装中文输入法scim-pinyi..._树莓派输入法图标不显示

什么是 immutable-程序员宅基地

文章浏览阅读2.5w次,点赞15次,收藏80次。immutable 基础入门什么是immutableimmutable(不可改变的)immutable是一种持久化数据。一旦被创建就不会被修改。修改immutable对象的时候返回新的immutable。但是原数据不会改变。原理:持久化数据结构为什么要使用immutable在Rudux中因为深拷贝对性能的消耗太大了(用到了递归,逐层拷贝每个节点)。但当你使用immutable数据的时候:只会拷贝你改变的节点,从而达到了节省性能。总结:immutable的不可变性让纯函数更强大,每次都_immutable

struts.xml 中配置常量constant详解_struts.xml constant-程序员宅基地

文章浏览阅读869次。一、配置:在struts2中配置常量的方式有三种:在struts.xml文件中配置 在web.xml文件中配置 在sturts.propreties文件中配置1.之所以使用struts.propreties文件配置,是因为为了保持与WebWork的向后兼容 2.在实际开发中,在web.xml中配置常量相比其他两种,需要更多的代码量,会降低了web.xml的可读性 3._struts.xml constant

偏最小二乘方法、ARX模型、有源自回归-神经网络结构建立ARX-NN模型、神经网络模型学习-程序员宅基地

文章浏览阅读937次。偏最小二乘方法是一种统计建模方法,用于处理多元线性回归问题。ARX模型(AutoRegressive with eXogenous inputs model)通常指的是自回归外生模型(Autoregressive Exogenous Model),它是一种时间序列模型,用于预测一个变量的未来值,基于该变量的过去值和一些外生变量。ARX-NN模型是在ARX模型的基础上引入神经网络结构的扩展模型。神经网络是一种模仿人脑神经系统结构和功能的计算模型。它由大量的人工神经元(节点)组成,并通过节点之间的连接_arx模型

高德地图鼠标划线显示距离并生成坐标点数据_高德地图鼠标画线-程序员宅基地

文章浏览阅读2.8k次,点赞3次,收藏9次。直接上代码,只需替换代码中你的高德key就可以看效果:<!doctype html><html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="chrome=1"> <meta..._高德地图鼠标画线

推荐文章

热门文章

相关标签