何时不需要微服务架构,Istio1.5告诉你

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介: 何时不需要微服务架构,Istio1.5告诉你

目录

已经走上了微服务的道路

有时还是会“回到整体”

Istio:微服务架构方式(V1.5之前)

微服务的好处

Istio1.5:从微服务到单一

结论


原文发表于kubernetes中文社区,为作者原创翻译 ,原文地址

更多kubernetes文章,请多关注kubernetes中文社区

过去五年中,我一直帮助企业进行云原生的实践。深刻体会到,当应用程序架构成为迭代的瓶颈时,微服务方法可能是合适的,但这不是唯一的方法

微服务不是“乌托邦式应用程序体系结构”。

关于这个主题,我也出了一本书--《Microservices for Java Developers》

尽管现在许多组织都已实现微服务架构,但远离微服务有时可能是最好的起点。


已经走上了微服务的道路

如果你已经走上了微服务之路,在无法使用微服务架构时请对自己和组织诚实,这会使你的产品更为成功。


有时还是会“回到整体”

出于各种考虑,组织使用了微服务,但有时还是会“回到整体”。

 

在为微服务通信构建服务网格Istio社区,控制平面的实现将逐渐从微服务方法变为更加单一的方法。谷歌API基础架构的首席工程师和架构师路易斯·瑞安Louis Ryan)在2019年KubeConNA的Istio聚会上,详细介绍了动机并在设计文档中介绍了该案例。从Istio 1.5(于2020年2月中旬)开始,我们就能看到该方法的效果,该方法将先前分配给各种微服务部署的功能合并为一个守护程序istiod

我们知道,Istio是用于帮助解决微服务/云架构所带来的挑战,那么Istio自身为何会脱离微服务架构?最直接的答案是:

事实证明,微服务方法的复杂性无法实现其预期的价值或目标。相反,它违背了这些目标。

对于Istio项目,“回到整体”可以更好地实现这些目标。


Istio:微服务架构方式(V1.5之前)

Istio是一个开源服务网格,其结构类似于具有控制平面和数据平面的服务网格实现。数据平面:由与每个应用程序实例一起存在并位于请求路径中的代理组成。控制平面:位于请求路径之外,用于管理和控制数据平面的行为。

Istio:微服务架构方式(V1.5之前)

 

从Istio1.5之前版本上看,Istio的控制平面是可作为单独部署的服务,该服务执行以下操作:

  • Pilot -核心数据平面--配置(xDS)服务器
  • Galley -配置监视,验证,转发
  • Injector -负责自动注入数据平面并设置引导程序
  • Citadel -证书签名,密钥生成,与CA集成等
  • Telemetry -一个“混合器”组件,负责将遥测数据聚合,并连接各种后端
  • Policy -负责执行策略的请求路径“混合器”组件

这些服务将由一组运营商定义的配置来驱动,并进行协调来服务和指导数据平面。


微服务的好处

微服务可以通过减少对整体系统的修改,来使组织快速迭代。在微服务架构下,每个服务可能会独立运行(每个服务都有自己的团队),并且具有彼此独立的发布节奏/生命周期。这将使开发人员和运维人员可以并行,而无需锁定/同步/协调来进行更改,从而提高部署和功能更改的速度。

细分服务的另一个原因是其使用模式和扩展属性。举一个简单的例子,需要大量读取和写入的服务可能会受益于将读写分离,因为读取可能会占用更多的内存(可能需要更多的缓存空间才能使读取速度更快),而写入可能会占用更多的存储空间或网络。你可以在机器/配额上扩展更多内存优化服务的读取部分,然后在具有SSD或EBS / SAN等机器上优化服务的写入部分。

将应用拆分为微服务的其他一些原因:

  • 安全问题
  • 域分组
  • 不同的语言优化
  • 服务的重要性

转到微服务架构时,第一要权衡的是复杂性。当你从一个事物(整体)变为一堆小事物,微服务彼此通信时复杂性就会增加。

如果微服务架构带给你了如上的好处,你有必要权衡下。如果没有,最好重新评估并纠正。这就是Istio目前正在发生的事情。


Istio1.5:从微服务到单一

首先要了解的是谁在开发和操作你的服务体系结构。在Istio社区中,项目中有不同的组成部分,可以在不同的社区工作组中看到。如果以较大规模的SaaS运行,则Istio控制平面作为一组微服务将可以很好地工作,但是在目前,情况似乎并非如此。

要了解的第二件事是如何完成发布?服务可以独立发布吗?在实践中,Istio的答案在理论上是“肯定的”,事实并非如此。当发布新版本的Istio时,你需要升级/部署所有控制面板组件。

最后,在Istio案例中,你可以问:“各个组件是否存在变量和安全问题的不同?” 实际上并没有。从Istio设计文档中可以看到:

Istio1.5之前,控制平面的成本由单个功能(服务XDS)控制。相比较而言,所有其他控制平面特征都具有边际成本,因此分离的价值很小。

为了安全起见,所有控制平面服务都具有相同的特权级别:

Istio1.5之前,,通过Webhook, Envoy Bootstrap & Pilot 所行使的权力在许多方面与 Citadel 相似

正如Istiod设计文档中的潜台词所言:“复杂性是万恶之源,或:我如何学会不再担心和喜欢上整体架构”

istiod是整体的化身,它以较低的复杂度支持了先前发行版的所有功能。请注意,组成Istio1.5之前版本的控制平面的服务仍被实现为项目内的子模块,但是操作经验得到了改善。运维人员现在需要担心运行和升级单个二进制文件还是它们的集合。

 

istiod

对于Istio进入单一控制平面,可以减少大量的复杂性,但是复杂性永远不会完全消失:

  • 仅通过一项可部署服务,使安装/升级变得更加容易
  • 由于不再需要用于协调服务的配置,因此降低了配置复杂性
  • 更容易调试问题(在一个地方还是所有地方看看)
  • 提高效率/减少传输,共享缓存等的开销

有关更多详细信息,请参见Istiod设计文档


结论

很高兴看到Istio社区继续改善其可用性和可操作性。对Istio控制平面进行整体部署对于该项目非常有意义。这对你的项目有意义吗?如果这样做,你会考虑吗?你会在什么时候衡量微服务体系结构的价值与它带来复杂性的关系,会不会也要“回归整体”?


译文链接: https://blog.christianposta.com/microservices/istio-as-an-example-of-when-not-to-do-microservices/


目录
相关文章
|
16天前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
16天前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
1天前
|
消息中间件 负载均衡 Cloud Native
云原生之旅:从容器到微服务的架构演变
在数字化转型的风潮中,云原生技术以其灵活性、可扩展性和弹性而备受青睐。本文将通过一个虚拟的故事,讲述一个企业如何逐步拥抱云原生,实现从传统架构向容器化和微服务架构的转变,以及这一过程中遇到的挑战和解决方案。我们将以浅显易懂的方式,探讨云原生的核心概念,并通过实际代码示例,展示如何在云平台上部署和管理微服务。
|
18天前
|
JSON 监控 安全
探索微服务架构中的API网关模式
【9月更文挑战第22天】在微服务架构的海洋中,API网关如同一位智慧的守门人,不仅管理着服务的进出,还维护着整个系统的秩序。本文将带你一探究竟,看看这位守门人是如何工作的,以及它为何成为现代云原生应用不可或缺的一部分。从流量控制到安全防护,再到服务聚合,我们将一起解锁API网关的秘密。
|
28天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
51 3
|
1月前
|
监控 负载均衡 应用服务中间件
探索微服务架构下的API网关设计与实践
在数字化浪潮中,微服务架构以其灵活性和可扩展性成为企业IT架构的宠儿。本文将深入浅出地介绍微服务架构下API网关的关键作用,探讨其设计原则与实践要点,旨在帮助读者更好地理解和应用API网关,优化微服务间的通信效率和安全性,实现服务的高可用性和伸缩性。
44 3
|
1月前
|
存储 Java Maven
从零到微服务专家:用Micronaut框架轻松构建未来架构
【9月更文挑战第5天】在现代软件开发中,微服务架构因提升应用的可伸缩性和灵活性而广受欢迎。Micronaut 是一个轻量级的 Java 框架,适合构建微服务。本文介绍如何从零开始使用 Micronaut 搭建微服务架构,包括设置开发环境、创建 Maven 项目并添加 Micronaut 依赖,编写主类启动应用,以及添加控制器处理 HTTP 请求。通过示例代码展示如何实现简单的 “Hello, World!” 功能,并介绍如何通过添加更多依赖来扩展应用功能,如数据访问、验证和安全性等。Micronaut 的强大和灵活性使你能够快速构建复杂的微服务系统。
64 5
|
15天前
|
Kubernetes Go Docker
掌握微服务架构:从Go到容器化的旅程
摘要,通常简短概述文章内容,要求精炼。在本文中,我们将打破常规,采用一种故事化叙述的摘要,旨在激发读者的好奇心和探究欲: “从宁静的海滨小城出发,我们踏上了一场技术探险之旅,探索微服务架构的奥秘。我们将学习如何用Go编写微服务,以及如何通过Docker和Kubernetes将它们打包进小巧的容器中。在这场旅程中,我们将遇到挑战、收获知识,最终实现应用的快速部署与可扩展性。”
|
16天前
|
Cloud Native Java 对象存储
揭秘微服务架构之争:Spring Cloud与Netflix OSS巅峰对决,谁将称霸弹性云原生时代?
近年来,微服务架构成为企业应用的主流设计模式。本文对比了两大热门框架Spring Cloud和Netflix OSS,探讨其在构建弹性微服务方面的表现。Spring Cloud依托Spring Boot,提供全面的微服务解决方案,包括服务注册、配置管理和负载均衡等。Netflix OSS则由一系列可独立或组合使用的组件构成,如Eureka、Hystrix等。两者相比,Spring Cloud更易集成且功能完善,而Netflix OSS则需自行整合组件,但灵活性更高。实际上,两者也可结合使用以发挥各自优势。通过对两者的对比分析,希望为企业在微服务架构选型上提供参考。
37 0
|
24天前
|
缓存 负载均衡 数据管理
深入探索微服务架构的核心要素与实践策略在当今软件开发领域,微服务架构以其独特的优势和灵活性,已成为众多企业和开发者的首选。本文将深入探讨微服务架构的核心要素,包括服务拆分、通信机制、数据管理等,并结合实际案例分析其在不同场景下的应用策略,旨在为读者提供一套全面、深入的微服务架构实践指南。**
**微服务架构作为软件开发领域的热门话题,正引领着一场技术革新。本文从微服务架构的核心要素出发,详细阐述了服务拆分的原则与方法、通信机制的选择与优化、数据管理的策略与挑战等内容。同时,结合具体案例,分析了微服务架构在不同场景下的应用策略,为读者提供了实用的指导和建议。