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

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

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

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

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

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

沟通效率问题

======

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

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

沟通效率往往会受到组织结构的影响。按照康威定律,我们的组织结构应该与我们的应用架构保持一致,最早践行微服务架构的亚马逊和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

智能推荐

分布式光纤传感器的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告_预计2026年中国分布式传感器市场规模有多大-程序员宅基地

文章浏览阅读3.2k次。本文研究全球与中国市场分布式光纤传感器的发展现状及未来发展趋势,分别从生产和消费的角度分析分布式光纤传感器的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品的价格、产量、产值及全球和中国市场主要生产商的市场份额。主要生产商包括:FISO TechnologiesBrugg KabelSensor HighwayOmnisensAFL GlobalQinetiQ GroupLockheed MartinOSENSA Innovati_预计2026年中国分布式传感器市场规模有多大

07_08 常用组合逻辑电路结构——为IC设计的延时估计铺垫_基4布斯算法代码-程序员宅基地

文章浏览阅读1.1k次,点赞2次,收藏12次。常用组合逻辑电路结构——为IC设计的延时估计铺垫学习目的:估计模块间的delay,确保写的代码的timing 综合能给到多少HZ,以满足需求!_基4布斯算法代码

OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版-程序员宅基地

文章浏览阅读3.3k次,点赞3次,收藏5次。OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版

关于美国计算机奥赛USACO,你想知道的都在这_usaco可以多次提交吗-程序员宅基地

文章浏览阅读2.2k次。USACO自1992年举办,到目前为止已经举办了27届,目的是为了帮助美国信息学国家队选拔IOI的队员,目前逐渐发展为全球热门的线上赛事,成为美国大学申请条件下,含金量相当高的官方竞赛。USACO的比赛成绩可以助力计算机专业留学,越来越多的学生进入了康奈尔,麻省理工,普林斯顿,哈佛和耶鲁等大学,这些同学的共同点是他们都参加了美国计算机科学竞赛(USACO),并且取得过非常好的成绩。适合参赛人群USACO适合国内在读学生有意向申请美国大学的或者想锻炼自己编程能力的同学,高三学生也可以参加12月的第_usaco可以多次提交吗

MySQL存储过程和自定义函数_mysql自定义函数和存储过程-程序员宅基地

文章浏览阅读394次。1.1 存储程序1.2 创建存储过程1.3 创建自定义函数1.3.1 示例1.4 自定义函数和存储过程的区别1.5 变量的使用1.6 定义条件和处理程序1.6.1 定义条件1.6.1.1 示例1.6.2 定义处理程序1.6.2.1 示例1.7 光标的使用1.7.1 声明光标1.7.2 打开光标1.7.3 使用光标1.7.4 关闭光标1.8 流程控制的使用1.8.1 IF语句1.8.2 CASE语句1.8.3 LOOP语句1.8.4 LEAVE语句1.8.5 ITERATE语句1.8.6 REPEAT语句。_mysql自定义函数和存储过程

半导体基础知识与PN结_本征半导体电流为0-程序员宅基地

文章浏览阅读188次。半导体二极管——集成电路最小组成单元。_本征半导体电流为0

随便推点

【Unity3d Shader】水面和岩浆效果_unity 岩浆shader-程序员宅基地

文章浏览阅读2.8k次,点赞3次,收藏18次。游戏水面特效实现方式太多。咱们这边介绍的是一最简单的UV动画(无顶点位移),整个mesh由4个顶点构成。实现了水面效果(左图),不动代码稍微修改下参数和贴图可以实现岩浆效果(右图)。有要思路是1,uv按时间去做正弦波移动2,在1的基础上加个凹凸图混合uv3,在1、2的基础上加个水流方向4,加上对雾效的支持,如没必要请自行删除雾效代码(把包含fog的几行代码删除)S..._unity 岩浆shader

广义线性模型——Logistic回归模型(1)_广义线性回归模型-程序员宅基地

文章浏览阅读5k次。广义线性模型是线性模型的扩展,它通过连接函数建立响应变量的数学期望值与线性组合的预测变量之间的关系。广义线性模型拟合的形式为:其中g(μY)是条件均值的函数(称为连接函数)。另外,你可放松Y为正态分布的假设,改为Y 服从指数分布族中的一种分布即可。设定好连接函数和概率分布后,便可以通过最大似然估计的多次迭代推导出各参数值。在大部分情况下,线性模型就可以通过一系列连续型或类别型预测变量来预测正态分布的响应变量的工作。但是,有时候我们要进行非正态因变量的分析,例如:(1)类别型.._广义线性回归模型

HTML+CSS大作业 环境网页设计与实现(垃圾分类) web前端开发技术 web课程设计 网页规划与设计_垃圾分类网页设计目标怎么写-程序员宅基地

文章浏览阅读69次。环境保护、 保护地球、 校园环保、垃圾分类、绿色家园、等网站的设计与制作。 总结了一些学生网页制作的经验:一般的网页需要融入以下知识点:div+css布局、浮动、定位、高级css、表格、表单及验证、js轮播图、音频 视频 Flash的应用、ul li、下拉导航栏、鼠标划过效果等知识点,网页的风格主题也很全面:如爱好、风景、校园、美食、动漫、游戏、咖啡、音乐、家乡、电影、名人、商城以及个人主页等主题,学生、新手可参考下方页面的布局和设计和HTML源码(有用点赞△) 一套A+的网_垃圾分类网页设计目标怎么写

C# .Net 发布后,把dll全部放在一个文件夹中,让软件目录更整洁_.net dll 全局目录-程序员宅基地

文章浏览阅读614次,点赞7次,收藏11次。之前找到一个修改 exe 中 DLL地址 的方法, 不太好使,虽然能正确启动, 但无法改变 exe 的工作目录,这就影响了.Net 中很多获取 exe 执行目录来拼接的地址 ( 相对路径 ),比如 wwwroot 和 代码中相对目录还有一些复制到目录的普通文件 等等,它们的地址都会指向原来 exe 的目录, 而不是自定义的 “lib” 目录,根本原因就是没有修改 exe 的工作目录这次来搞一个启动程序,把 .net 的所有东西都放在一个文件夹,在文件夹同级的目录制作一个 exe._.net dll 全局目录

BRIEF特征点描述算法_breif description calculation 特征点-程序员宅基地

文章浏览阅读1.5k次。本文为转载,原博客地址:http://blog.csdn.net/hujingshuang/article/details/46910259简介 BRIEF是2010年的一篇名为《BRIEF:Binary Robust Independent Elementary Features》的文章中提出,BRIEF是对已检测到的特征点进行描述,它是一种二进制编码的描述子,摈弃了利用区域灰度..._breif description calculation 特征点

房屋租赁管理系统的设计和实现,SpringBoot计算机毕业设计论文_基于spring boot的房屋租赁系统论文-程序员宅基地

文章浏览阅读4.1k次,点赞21次,收藏79次。本文是《基于SpringBoot的房屋租赁管理系统》的配套原创说明文档,可以给应届毕业生提供格式撰写参考,也可以给开发类似系统的朋友们提供功能业务设计思路。_基于spring boot的房屋租赁系统论文