文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

一文告诉你Istio和Spring Cloud该怎么选

2024-12-13 15:32

关注

相信了解SpringCloud的朋友在刚刚开始接触Istio的时候一定会有一个疑问:Istio和 spring cloud也太像了,他们都可以提供服务发现、负截均衡、限流、链路跟踪、鉴权等微服务治理手段,那么二者的主要区别是什么呢?本文就会带大家理解二者的区别,如果您目前对微服务和 Service Mesh还不了解,那么请您忽略本文。

Istio 概述

Istio 是一个开源服务网格(Service Mesh),它透明地分层到现有的分布式应用程序上。 Istio 强大的特性提供了一种统一和更有效的方式来保护、连接和监视服务。 Istio 是实现负载平衡、服务到服务身份验证和监视的路径——只需要很少或不需要更改服务代码。

它强大的控制平面带来了重要的特点,包括:

SpringCloud概述

Spring Cloud为开发人员提供了用于快速构建分布式系统中某些常见模式的工具(例如,配置管理,服务发现,断路器,智能路由,微代理,控制总线)。主要涉及的组件包括:
Eureka:注册中心
Zuul:服务网关
Rbiibon:负载均衡
Feign:服务调用
Hystrix:熔断器

Istio 和Spring Cloud的区别

大家会发现:Istio和 spring cloud都可以提供服务发现、负截均衡、限流、链路跟踪、鉴权等微服务治理手段,那么二者的主要区别是什么呢?

1、Istio 使用功能强大的 Envoy 服务代理扩展了 Kubernetes,kubernetes本身是一个运维平台,而Spring cloud只是一个开发框架,所以这就注定了Istio在运维层面更为优秀,下图说明了kubernetes和Spring cloud的差异

Istio通过K8S API收集了Service信息来接管后续工作,把流量转发控制权交给了由C++开发的Envoy,Envoy就是Istio的 Sidecar。因此Istio更注重运维而Spring cloud更注重开发;

2、Istio 支持多语言(Istio 实现了Service Mesh,而Service Mesh的核心是改变通信和服务治理能力的提供的方式,通过将这些能力实现从各语言业务实现中解耦,下沉到基础设施层面,以一种更加通用和标准化的方式提供,屏蔽不同语言、不同平台的差异性,有利于通信和服务治理能力的迭代和创新,使得业务实现更加方便。Service Mesh避免了多语言服务治理上的重复建设,通过Service Mesh语言无关的通信和服务治理能力,助力于多语言技术栈的效率提升);SpringCloud体系的缺点是语言只能指定Java;

3、个人认为最重要的是spring cloud 是侵入式微服务,Istio是非侵入式微服务。在Istio中服务发现,注册,调用,负载均衡,降级熔断隔离,网关都是非侵入式的,不需要程序员关心,不需要加入依赖和注解。

从下面这张图中,就可以更为清晰地看到,Istio与springcloud的差异

二者的选择

看到这里,大家一定会认为在Istio和SpringCloud的比较中,Istio会完胜!因为Istio的出现为微服务架构减轻了很多的负担,开发者不需要关心服务调用的超时、重试、rate limit 的实现,服务之间的安全、授权也自动得到了保证;集群管理员也能够很方便地发布应用(AB 测试和灰度发布),并且能清楚看到整个集群的运行情况。

但是这并不表明有了 Istio 就可以高枕无忧了,Istio 只是把原来分散在应用内部的复杂性统一抽象出来放到了统一的地方,并没有让原来的复杂消失不见。因此我们需要维护 Istio 整个集群,而 Istio 的架构比较复杂,一般需要基于 kubernetes 之上,这两个系统都比较复杂,而且它们的稳定性和性能会影响到整个集群。

因此在采用Isito 之前,必须做好清楚的规划,权衡它带来的好处是否远大于额外维护它的花费,需要有相关的人才对整个网络、kubernetes 和 Istio 都比较了解才行。下图做了一个关于Istio和springcloud的总结,大家可以自行判断选择哪种框架。

来源:今日头条内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯