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本身不处理事务,但可以与外部系统如数据库或消息队列结合,通过两阶段提交等协议来处理分布式事务。
相关推荐
Small black human1 小时前
Spring-MyBatis的配置
java·spring·mybatis
王有品3 小时前
Spring MVC 会话管理实践教程:HttpSession 深入应用
java·spring·mvc
武子康3 小时前
Java-49 深入浅出 Tomcat 手写 Tomcat 实现【02】HttpServlet Request RequestProcessor
java·开发语言·后端·学习·spring cloud·tomcat
不知疲倦的仄仄5 小时前
RabbitMQ多角度可靠性分析/基于Java代码深度解析
java·spring·rabbitmq·java-rabbitmq
tswddd5 小时前
项目:Gitlab HSD CI/CD总结
ci/cd·kubernetes·gitlab
lwb_01187 小时前
Spring MVC参数绑定终极手册:单&多参对象集合JSON文件上传精讲
spring·json·mvc
18你磊哥8 小时前
Docker Compose部署Spring Cloud 微服务系统
spring cloud·docker·微服务
郝同学的测开笔记10 小时前
深入理解 kubectl port-forward:快速调试 Kubernetes 服务的利器
后端·kubernetes
Cloud孙文波13 小时前
k8s 收集event事件至Loki
云原生·kubernetes·event
trow13 小时前
Spring 手写简易IOC容器
后端·spring