谈谈我理解的SpringCloud和Kubernetes的区别

这篇具有很好参考价值的文章主要介绍了谈谈我理解的SpringCloud和Kubernetes的区别。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  • B站:https://www.bilibili.com/video/BV1R24y1u7a2

  • 小道仙学习文档: https://d9bp4nr5ye.feishu.cn/wiki/wikcnkGEgfYwJspeNdXMegfQjQh


一、起源

为什么想写这篇文章呢?起源于我最开始对于它俩的误解,在很长一段时间我都分不清它们的区别。

对于SpringCloud在实际项目中并未使用过,只是自学过SpringCloud和SpringCloud Alibaba,也基于学习搭建过demo。

对于Kubernetes,目前这家公司就是使用的这个,但也只是管中窥豹,目前对于二者的关系,以及一些优缺点,还是有点认识的。

基于学习、总结的想法,然后就出了这篇文章,下面以对比的方式来介绍它们俩。


二、框架图

这个是我21年学习cloud画的流程图
谈谈我理解的SpringCloud和Kubernetes的区别


这是基于我理解的K8S画的图

谈谈我理解的SpringCloud和Kubernetes的区别

三、功能对比


下面这个问题的回答来自 chatGPD

SpringCloud 和 Kubernetes的区别

Spring Cloud 和 Kubernetes 都是用于构建和管理云原生应用程序的工具,但它们有一些重要的区别。
Spring Cloud 是一组用于构建微服务架构的框架和库。它提供了一系列解决方案,如服务注册、配置管理、负载均衡、断路器、路由和追踪等功能。Spring Cloud 建立在 Spring Framework 的基础上,它的目标是让开发人员能够更轻松地构建和管理微服务架构。Spring Cloud 可以运行在任何基础设施上,包括本地服务器、虚拟机和云环境。
Kubernetes 是一个容器编排平台,它允许用户自动化部署、扩展和管理容器化应用程序。Kubernetes 提供了许多功能,如服务发现、负载均衡、自动伸缩、滚动更新、容器存储和自动恢复等。Kubernetes 的设计目标是支持大规模的容器集群,它可以在任何基础设施上运行,包括本地服务器、公有云和私有云环境。
因此,Spring Cloud 和 Kubernetes 的主要区别在于它们的设计目标和重点。Spring Cloud 主要关注构建微服务架构,提供了一系列解决方案,而 Kubernetes 主要关注容器编排,提供了一套自动化部署、扩展和管理容器化应用程序的功能。当构建和管理微服务架构时,可以使用 Spring Cloud,当部署和管理容器化应用程序时,可以使用 Kubernetes。

就我的使用体验来说,我觉得它们并不是对立的,不是说用了K8S就不可以使用SpringCloud,相反我觉得它们是可以相互补充的。


1、服务网关

网关简单来说就是一个大门,你想要去访问门后的东西,第一步就是跨过大门。

  • Cloud里面的网关代表有zuul、Gateway等,它们需要去连接一个注册中心,去注册中心拿到服务相关的信息,再去做相对的转发策略。
  • K8S的网关是 ingress,目前我们的服务是部署在阿里云上面的,使用的是 nginx ingress controller,本质上是基于nginx + luajit 来实现的,借助luajit框架可以让我们像编程一样的去操作nginx能力。(可以去看看开源框架 OpenResty)

以我的使用体验来看,我更喜欢 ingress,它依托k8s本身,新增服务的时候会自动的去发现服务,我们的服务本身没有任何的依赖,比如配置注册中心地址什么的,部署即刻生效。


2、服务注册/发现

  • Cloud的服务注册发现,是需要借助其它中间件比如Eureka、Nacos等,这些组件也还需要借助第三方的存储比如MySQL。
  • K8S的数据存储是ETCD,理所当然服务信息也会存储到这个里面,自然就形成了注册,ingress会从etcd里面获取信息,就形成了服务的发现,完全是K8S自带的。

3、服务调用

不管是cloud还是k8s,其实服务本身的通信是没有什么限制的,比如你可以使用HTTP,也可以用 RPC。

相对于cloud,k8s服务调用更有优势,你注册了一个服务,会生成一个服务内部调用地址,通过这个地址去调用服务走内部通信,一个是快,一个是自带负载均衡。

如果你想使用RPC调用,在K8S里面也是完全可以的,我们的服务就在慢慢的开始使用OpenFegin,目的是为了统一技术站,为后续服务治理做准备。


4、服务配置

  • Cloud 里面的配置中心有config、nacos等,可以做到热更新,也可以做到不同的环境不同的配置。
  • K8S里面可以使用configMap,它就是一个 key-value 格式的数据,我们的value可以是任何格式的数据,这取决于我们的服务想用什么比如 Java里面的 yaml,nginx里面的conf。

从功能来看nacos是全胜的,但是从业务场景来看,有时候configMap更适合我们

  1. 热更新:nacos是支持热更新的,configMap不支持,不过K8S的pod支持滚动升级,偶尔的一次修改配置文件也可以做到用户无感知,只是操作稍微麻烦些,需要重启。
  2. 编写体验:nacos有很好的编辑器,不同的文件会有不同的高亮显示,但是阿里云的configMap目前只是一个单纯的文本框。(这点我也无所谓,一般我都是复制出来的本地编辑再复制回去)
  3. 难易度:毫无疑问configMap属于K8S本身肯定要简单很多不需要单独的服务并且代码无任何侵入。

5、服务熔断、降级

K8S和Cloud一样需要引入第三方中间件,如 sentinel和hystrix

谈谈我理解的SpringCloud和Kubernetes的区别


6、分布式事务

同上,也需要引入第三方中间件,或自己做补偿机制


四、总结

个人觉得它们最大的区别在于一个是为了解决Java微服务架构问题,一个是容器架构和语言无关,所有功能都是自己这个架构所自带的,只是为了解决架构的某些问题而产生的。文章来源地址https://www.toymoban.com/news/detail-503999.html

到了这里,关于谈谈我理解的SpringCloud和Kubernetes的区别的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 谈谈你对 Spring AOP 的理解

    Java面试目录 谈谈你对 Spring AOP 的理解 Spring AOP是面向切面编程,通过代理模式来实现。 我们将与业务逻辑无关,同时又需要在业务执行前后调用的逻辑封装起来,利用代理来进行统一调度。可以减少系统的重复代码,降低耦合度,增加可维护性。使用场景包括:事务处理,

    2024年01月22日
    浏览(47)
  • 让我们谈谈你对 ThreadLocal 的理解

    从 JDK1.2 开始,ThreadLocal 是一个被用来存储线程本地变量的类。在 ThreadLocal 中的变量在线程之间是独立的。当多个线程访问 ThreadLocal 中的变量,它们事实上访问的是自己当前线程在内存中的变量,这能确保这些变量是线程安全的。 我们通常使用 ThreadLocal 解决线程中的变量冲

    2023年04月16日
    浏览(38)
  • 谈谈Nacos跟Eureka的区别

    目录 CAP上的区别 检测机制  连接方式 自我保护 Eureka和Nacos都是服务注册与发现的组件,都支持服务注册和服务拉取,都支持服务提供者心跳方式做健康检测, Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务治理 ,在传统的rpc远程调用框架中,管理每个服务与服务

    2024年02月04日
    浏览(44)
  • 谈谈ArrayList和LinkedList的区别

    目录 一、什么是数组 二、ArrayList 三、LinkedList 四、ArrayList和LinkedList的区别 在编程中,数组(Array)是一种用于存储多个相同类型数据元素的数据结构。它是一个有序的集合,其中每个元素都有一个唯一的索引(下标),用于访问和操作数组中的元素。 数组通常用于存储数据

    2024年01月21日
    浏览(45)
  • 【面试题】谈谈你对IOC和AOP的理解

    IoC(Inverse of Control:控制反转)是一种设计思想,就是将 原本在程序中手动创建对象的控制权,交由Spring框架来管理 。IOC思想是基于IOC容器来完成的,IOC容器底层就是对象工厂(BeanFactory接口)。IOC的原理是基于xml解析、工厂设计模式、反射来实现的。 IoC 容器实际上就是个

    2024年02月05日
    浏览(79)
  • 1、什么是面向对象?谈谈你对面向对象的理解

    对比面向过程,是两种不同的处理问题的角度 面向过程更注重事情的每一个步骤及顺序,面向对象更注重事情有哪些参与者(对象)、及各自需要做什么 比如 : 洗衣机洗衣服 面向过程会将任务拆解成一系列的步骤(函数),1、打开洗衣机 …2、放衣服…3、放洗衣粉…4、清洗…

    2024年02月13日
    浏览(42)
  • 谈谈CPU,MCU,SOC的区别和用途

    很多刚学习嵌入式的同学困惑经常看到CPU,MCU,SOC这几个名词,难道是同一样东西吗? 其实不是。它们之间还是有区别的。 让我们深入了解它们之间的区别,探索它们在计算世界中各自的作用。 中央处理器,或称为CPU,是计算机的大脑。它是一块硅芯片,负责执行计算机程

    2024年01月19日
    浏览(49)
  • 【面试八股文】每日一题:谈谈你对异常的理解

    每日一题-Java核心-谈谈你对异常的理解【面试八股文】   异常是程序在运行过程中出现的错误或不正常的情况。当程序执行过程中遇到无法处理的错误或者不符合预期的情况,就会抛出异常。异常可以分为两种类型: 受检异常 和 非受检异常 。    受检异常 是指在程序

    2024年02月13日
    浏览(56)
  • 【面试八股文】每日一题:谈谈你对线程的理解

    每日一题-Java核心-谈谈你对线程的理解【面试八股文】   Java线程是Java程序中的执行单元。一个Java程序可以同时运行多个线程,每个线程可以独立执行不同的任务。线程的执行是并发的,即多个线程可以同时执行。   Java中的线程有如下的特点 轻量级:线程的创建和销毁

    2024年02月12日
    浏览(45)
  • 谈谈ES5和ES6的区别

    我们都知道JavaScript是由三部分组成: 1. ECMAScript(核心):规定了语言的组成部分=语法、类型、语句、、保留字、操作符、对象 2. BOM(浏览器对象模型): 支持访问和操作浏览器窗口,可以控制浏览器显示页面以外的部分。 3. DOM(文档对象模型): 把整个页面映射为一个多层节

    2024年02月02日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包