SpringCloud和K8s的区别

  1. 服务发现与注册

    • Spring Cloud中的Eureka组件提供了服务注册与发现的功能,允许微服务相互查找并通信。
    • Kubernetes中的kube-apiserver作为控制平面的一部分,提供了服务发现的能力,允许系统内部组件和外部客户端通过API发现和访问集群中的服务。
  2. 配置管理

    • Spring Cloud的Config Server提供了集中化的配置管理功能,支持配置信息的动态更新。
    • Kubernetes使用ConfigMapsSecrets 来管理配置数据和敏感信息,并通过kube-controller-manager中的控制器来处理这些资源对象。
  3. API网关

    • Spring Cloud的Gateway组件作为API网关,负责请求路由、过滤器链处理等。
    • Kubernetes中的Ingress 资源与Ingress Controller一起工作,也充当API网关,处理外部访问集群服务的路由。
  4. 负载均衡

    • Spring Cloud的Ribbon组件提供了客户端负载均衡功能,可以在多个服务实例间分配请求。
    • Kubernetes中的kube-proxy负责在集群中的各个节点上进行网络代理和负载均衡。
  5. 断路器模式

    • Spring Cloud的Hystrix组件实现了断路器模式,防止服务间的级联故障。
    • Kubernetes通过Pod 的健康检查和重启策略,以及Deployment资源的副本管理,来确保服务的可用性和容错性。
  6. 分布式追踪

    • Spring Cloud的Sleuth组件提供了分布式追踪解决方案,帮助开发者跟踪请求在微服务间的流动。
    • Kubernetes虽然没有内置的分布式追踪组件,但是可以集成如Jaeger等开源追踪系统来实现相似的功能。
  7. 服务容错

    • Spring Cloud的Sentinel组件提供了服务容错功能,包括限流、降级、熔断等。
    • Kubernetes通过Liveness ProbesReadiness Probes来检测容器健康状况,并在必要时进行适当的恢复操作。
  8. 分布式事务

    • Spring Cloud Alibaba的Seata组件提供了分布式事务解决方案,协调跨多个服务的事务一致性。
    • Kubernetes本身不处理事务,但可以与外部系统如数据库或消息队列结合,通过两阶段提交等协议来处理分布式事务。
相关推荐
cxyxiaokui00121 分钟前
🔥不止于三级缓存:Spring循环依赖的全面解决方案
java·后端·spring
珹洺3 小时前
Java-Spring入门指南(二十六)Android Studio下载与安装
java·spring·android studio
cxyxiaokui0013 小时前
JDK 动态代理 vs CGLIB:原理、区别与 Spring AOP 底层揭秘
java·后端·spring
能不能别报错4 小时前
K8s学习笔记(二十) 亲和性、污点、容忍、驱逐
笔记·学习·kubernetes
舰长1154 小时前
k8s 持久化存储方案-NFS
云原生·容器·kubernetes
珹洺4 小时前
Java-Spring入门指南(二十五)Android 的历史,认识移动应用和Android 基础知识
android·java·spring
ajsbxi5 小时前
【Redis】缓存读/写操作流程
redis·笔记·spring·缓存·bootstrap
艾菜籽6 小时前
SpringMVC练习:加法计算器与登录
java·spring boot·spring·mvc
程序员小凯7 小时前
Spring MVC 多租户架构与数据隔离教程
spring·架构·mvc
Knight_AL7 小时前
代理模式 vs AOP:支付服务中的日志增强实践(含执行顺序详解)
spring·代理模式