为什么你会觉得微服务架构很别扭

本文涉及的产品
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介:
很多系统迁移到微服务架构之后,并没有明显感觉到微服务架构带来的优势,反而觉得带来了更高的复杂度,王启军在《持续演进的Cloud Native》书中总结了七种微服务架构没能发挥出固有优势的原因,看看自己“中枪”了没!

1、用传统方式构建微服务

微服务架构和传统的架构方式思路完全不一样。例如传统方式实现高可用,更相信流程,更相信KPI对人的影响,因此流程需要让更多的人去测试,制定更严格的发布流程。
而微服务架构强调的是自动化发布、灰度发布、Design For Failure、自动化测试、故障隔离、自愈。很多失败的案例以传统的方式去构建微服务架构,一切都没有转变,只是把服务拆开,根本无法享受微服务架构带来的便利,反而因此遇到了更多麻烦。最明显的是对开发人员的影响,他们质疑微服务架构是否适合自己的业务场景,而一个充满质疑的团队是不可能具备强大战斗力的。
dd80b873a295012c0d622027b0cad15532685bc8

2、组织结构不变

如果要充分发挥微服务架构的优势,组织结构必须发生转变,构建和微服务配套的小团队,并且让他们拥有绝对的自主权。实际上,相当一部分实施微服务架构的团队都没有做到这一点,因为组织结构总是涉及利益。比较典型的问题是,小团队不需要团队以外的任何人来批准是否上线,架构如何演进,使用什么数据库。如果小团队没有权利,任何变动都要等待高层进行决策,就会形成决策瓶颈点,导致效率低下,这违背了微服务架构的初衷,团队成员也会因此失去主动性。
d6c1e399df1ed8f2715fd01d4c82e0dc19585730

3、习惯于领导安排工作

传统的研发模式严重依赖流程,原因是没有人愿意承担责任,所有人都把责任推到流程上。微服务架构和敏捷开发流程是天作之合,传统研发模式需要领导批准,然后由团队负责人直接分解任务、定工时、安排任务负责人,而按照敏捷开发流程,开发计划应该是团队决定的,任务自主认领。精英化团队绝不仅仅是团队人数更少,人员能力更强这么简单,这只是表面上的,更重要的是责任感和主观能动性以及信任!
某公司CEO 曾经说过这样一件事情,员工把请假流程提给“我”,让“我”审批,但是“我”根本没有审批的必要,因为你随便说一个理由“我”都不可能拒绝,就算拒绝了,下回会来一个更难以拒绝的理由。后来公司所有的请假都不需要审批了,只要在群里发一条消息,让相关同事知道就可以了。
5d609ae5e90b17645246e625bf2e10894b212441

4、纠结如何拆分服务

不理解微服务架构的人,通常从字面理解,他们认为微服务架构的重中之重就是服务拆分。
到底拆分多细?与其浪费更多的时间思考这个问题,不如先拆出几个服务运行一下,感受一下。架构是一个持续的过程,有时候很难从技术角度完全解释清楚。
另一个错误是一次性拆分,不能改变。由于技术人员对业务领域知识的理解不断加深,业务逻辑有可能运行一段时间也会转变,这时候改变是不可避免的。重新合并、划分,是一个正常的演变过程。架构是动态的,不是静态的。
e82ed1529db3cedfdc908451e16510c35e6c04dc

5、以大规模拆分服务开始

微服务架构需要一个适应过程,持续拆分效果更佳。如果从大规模拆分服务开始,需要具备三个条件,否则可能会遇到相当多的麻烦。
  • 团队有微服务架构经验。
  • 已具备微服务架构的先决条件,包括自动化的研发环境、全面的健康检查、必要的公共服务及框架,以及敏捷基础设施。
  • 业务目标非常明确,已经可以预期未来的规模,业务几乎无变化。
be2187a48499ae06ed81ca4a31e04c7501991568

6、高估架构的移植性

架构是一门艺术,不是随随便便复制一下就可以的,Google、Amazon、Facebook 的架构问世已经很长时间了,研发人员跳槽这么频繁,但是没有哪个公司能模仿好。MySQL 开源了这么多年,放到不同人的手里,结果完全不一样。实际上实施微服务架构在一个业务场景中的优势在另一个场景中很可能会变成一种劣势。如果你仔细研究就会发现,大多数公司实施的微服务架构就跟各个公司的管理制度一样各不相同。很多公司为了显示自己的架构有多厉害而实施微服务架构,最终只会害了团队,因为只把精力放在微服务架构上,可能就减少了对业务实现、用户体验的关注。
3dbaeb5819a1a00b7a2a521d130aae8bb8eefc1a

7、从来没有做过微服务架构的人领导你完成迁移

如果转型的团队由没有经验的人来领导,那么结果就是只关注表面,拆了多少服务、服务粒度、服务注册发现、负载均衡、调用链分析,而隐藏的各种性能问题、扩展性问题、可用性问题都没有得到足够的关注。如果只是从几个服务拆分开始积累经验还好,一旦大规模拆分,就会让整个团队都质疑微服务架构的意义。架构是需要实践的,不要以为看几篇文章就得到了架构的真谛,细节会“杀死”团队。
1cd2580b26a22d8de2a6ad7aeae379b356e18226

本文选自《持续演进的Cloud Native:云原生架构下微服务最佳实践》,作者王启军 ,电子工业出版社10月出版。
作者从全局视角出发,全面阐释Cloud Native 的关键技术,以及其衍生出来的工具、团队文化等核心要素,对于正在部署微服务架构或开展云原生业务的企业和组织而言,终于有了面向落地的务实参考和全面指导。
5a72d21f43f7d95d3f7cfc6e86f3c9cdb714fc88
相关文章
|
12天前
|
缓存 监控 API
探索微服务架构中的API网关模式
【10月更文挑战第5天】随着微服务架构的兴起,企业纷纷采用这一模式构建复杂应用。在这种架构下,应用被拆分成若干小型、独立的服务,每个服务围绕特定业务功能构建并通过HTTP协议协作。随着服务数量增加,统一管理这些服务间的交互变得至关重要。API网关作为微服务架构的关键组件,承担起路由请求、聚合数据、处理认证与授权等功能。本文通过一个在线零售平台的具体案例,探讨API网关的优势及其实现细节,展示其在简化客户端集成、提升安全性和性能方面的关键作用。
45 2
|
16天前
|
存储 缓存 监控
探索微服务架构中的API网关模式
【10月更文挑战第1天】探索微服务架构中的API网关模式
48 2
|
1月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
1月前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
2天前
|
负载均衡 监控 Cloud Native
云原生架构下的微服务治理策略与实践####
在数字化转型加速的今天,云原生技术以其高效、灵活、可扩展的特性成为企业IT架构转型的首选。本文深入探讨了云原生环境下微服务治理的策略与实践路径,旨在为读者提供一个系统性的微服务治理框架,涵盖从服务设计、部署、监控到运维的全生命周期管理,助力企业在云端构建更加稳定、高效的业务系统。 ####
|
3天前
|
运维 监控 Cloud Native
云原生架构下,微服务治理的艺术与实践####
【10月更文挑战第14天】 在数字化转型的大潮中,云原生技术以其高效、灵活与可扩展性成为企业IT架构的首选。本文深入探讨了云原生架构的核心理念,聚焦于微服务治理的策略与实践,揭示了如何通过精细化管理提升系统的响应速度、稳定性和可维护性。不同于传统的摘要概述,本文摘要旨在直接触及读者关注的核心——即如何在复杂多变的云环境中,实现微服务的高效协同与治理,为读者提供一个清晰的行动指南。 ####
11 1
|
13天前
|
Kubernetes 安全 微服务
使用 Istio 缓解电信 5G IoT 微服务 Pod 架构的安全挑战
使用 Istio 缓解电信 5G IoT 微服务 Pod 架构的安全挑战
38 8
|
17天前
|
消息中间件 负载均衡 Cloud Native
云原生之旅:从容器到微服务的架构演变
在数字化转型的风潮中,云原生技术以其灵活性、可扩展性和弹性而备受青睐。本文将通过一个虚拟的故事,讲述一个企业如何逐步拥抱云原生,实现从传统架构向容器化和微服务架构的转变,以及这一过程中遇到的挑战和解决方案。我们将以浅显易懂的方式,探讨云原生的核心概念,并通过实际代码示例,展示如何在云平台上部署和管理微服务。
|
1月前
|
JSON 监控 安全
探索微服务架构中的API网关模式
【9月更文挑战第22天】在微服务架构的海洋中,API网关如同一位智慧的守门人,不仅管理着服务的进出,还维护着整个系统的秩序。本文将带你一探究竟,看看这位守门人是如何工作的,以及它为何成为现代云原生应用不可或缺的一部分。从流量控制到安全防护,再到服务聚合,我们将一起解锁API网关的秘密。
|
1月前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
116 3