首页 > 其他分享 >Spring Cloud vs Istio微服务治理框架对比

Spring Cloud vs Istio微服务治理框架对比

时间:2023-02-08 21:03:26浏览次数:53  
标签:服务 Spring Istio vs 治理 版本 Cloud

目前主流的微服务治理框架主要是Spring Cloud。而Istio作为新一代微服务框架,越来越受到关注。Istio被引入的主要原因是传统微服务存在以下问题。

  • 多语言技术栈不统一:C++、Java、PHP、Go。Spring Cloud无法提出非Java语言的微服务治理。
  • 服务治理周期长:微服务治理框架与业务耦合,上线周期长,策略调整周期长。
  • 产品能力弱:Spring Cloud缺乏平台化和产品化的能力,可视化能力弱。

那么如何选择Spring Cloud与Istio,这里有个简单的对比。

Spring Cloud vs Istio微服务治理框架对比_微服务治理

如果企业的开源语言主要是Java、更新升级不频繁、无过多高级治理功能需求、业务规模不是非常大,使用Spring Cloud是比较合适的。那么引入Istio的成本如何?

Spring Cloud vs Istio微服务治理框架对比_微服务治理_02

Spring Cloud和Istio实现的企业微服务治理进行对比。

Spring Cloud vs Istio微服务治理框架对比_微服务治理_03

从开放性以及先进性角度来说,建议将服务网格Istio作为首选微服务应用框架。Istio运维方面的建议包括版本选择、备用环境、评估范围、配置生效、功能健壮性参考、入口流量选择。当然,这些建议都是基于当前的使用情况。随着Istio使用越来越广泛,相信最佳实践将会越来越丰富。

  1. 版本选择

Istio是一个迭代很快的开源项目。频繁的版本迭代会给企业带来一些困扰:是坚持使用目前已经测试过的版本,还是使用社区的最新版本?出于安全性和稳定性的考虑,红帽Istio往往比社区要晚两个小版本左右。因此建议使用红帽Istio的最新版本。目前看,社区的最新版本的Istio的稳定性往往不尽如人意。

  1. 备用环境

针对相同的应用,在环境中部署一套不被Istio管理的环境。这样做的好处是,每当进行Istio升级或者部分参数调整时都可以提前进行主从切换,让流量切换到没有被Istio管理的环境中,将Istio升级调整验证完毕后再将流量切换回来。

  1. 评估范围

由于Istio对微服务的管理是非代码侵入式的。因此通常情况下,业务服务需要进行微服务治理,需要被Istio纳管。而对于没有微服务治理要求的非业务容器,不必强行纳管在Istio中。当非业务容器需要承载业务时,被Istio纳管也不需要修改源代码,重新注入Sidecar部署即可。

  1. 配置生效

如果系统中已经有相关对象的配置,我们需要使用oc replace -f指定配置文件来替换之前配置的对象。Istio中有的配置策略能够较快生效,有的配置需要一段时间才能生效,如限流、熔断等。新创建策略(oc create -f)的生效速度要高于替换性策略(oc replace -f)。

因此在不影响业务的前提下,可以在应用新策略之前,先删除旧策略。此外,Istio的配置生效,大多是针对微服务所在的项目,但也有一些配置是针对Istio系统。因此,在配置应用时,要注意指定对应的项目。

  1. 功能健壮性参考

健壮性较强的功能有基于目标端的蓝绿、灰度发布,基于源端的蓝绿、灰度发布,灰度上线,服务推广,延迟和重试,错误注入,mTLS,黑白名单。健壮性有待提升的功能有限流和熔断。

  1. 入口流量方式

在Istio体系中的应用不使用Router也可以正常访问微服务。但是PaaS上运行的应用未必都是Istio体系下的,其他非微服务或者非Istio体系下的服务还是要通过Router访问。此外,Istio本身的监控系统和Kiali的界面都是通过Router访问的。

相比Spring Cloud,Istio较好地实现了微服务的路由管理。但在实际生产中,仅有微服务的路由管理是不够的,还需要诸如不同微服务之间的业务系统集成管理、微服务的API管理、微服务中的规则流程管理等。

标签:服务,Spring,Istio,vs,治理,版本,Cloud
From: https://blog.51cto.com/key3feng/6044892

相关文章

  • TVS二极管
    1、TVS二极管原理图符号  2、TVS二极管的工作原理TVS二极管(单向)反接并入电路中,当电路正常工作时,TVS二极管处于OFF状态,只消耗一定的漏电流。当电路出现异常过电压并......
  • 【Spring】Spring框架入门案例
    1.下载Spring5(1)Spring官网https://spring.io/(2)下载地址https://repo.spring.io/ui/native/release/org/springframework/spring/下载解压,文件夹说明2.创建普通Java......
  • SpringMVC源码(一):源码运行环境搭建
    一、创建smvc子模块子模块选择gradle二、实体类代码2.1、User实体1publicclassUser{23privateStringname;45publicUser(){6}......
  • 【Spring】Spring框架概述
    1.Spring是轻量级的开源的框架轻量级:jar包较少较小开源:免费提供源代码2.Spring可以解决企业应用开发的复杂性3.Spring有两个核心部分:IOC、AOP(1)IOC:控制反转,把创建对象......
  • Spring声明式事务的工作原理
    Spring事务管理Java后端项目开发中都会用到的一个技术点,每个Java工程师都必须精通。Spring事务管理可以分为两类:声明式事务管理编程式事务管理声明式事务管理只需要......
  • cocosCreator VSCode 插件没有代码提示的问题
    cocosCreatorVSCode插件没有代码提示,并且代码出现莫名的错误提示如下解决方案:在CocosDashboard的安装目录下的CocosDashboard\resources.editors\Creator\3......
  • springboot 动态获取配置信息完成启动
    架构说设计到数据量较大的应用要从k8s中迁出单独机器部署于是将8节点的服务准备迁出,且端口号在数据库中保存在不引入springcloud的方式下启动spring容器中对args进行配......
  • Spring30 - Resource资源读取
    资源操作:Resources8.1、SpringResources概述Java的标准java.net.URL类和各种URL前缀的标准处理程序无法满足所有对low-level资源的访问,比如:没有标准化的URL实现可用......
  • 在VSCode中的markdown里插入混淆矩阵HTML源码
    最近在看论文的时候习惯用markdown记录笔记,就有了如题的需求。由于原生的markdown不能合并表格的单元格(或者我不知道,OS:真菜),但是markdown支持HTML,直接写一段代码扔进去就......
  • SpringBoot工程入门case
    SpringBoot的设计目的是用来简化Spring应用的初始搭建以及开发过程。SpringBoot入门案例:1、创建一个新module  2、除pom和src文件剩余都删除。  3、在src.com......