首页 > 其他分享 >SpringCloud:Consul

SpringCloud:Consul

时间:2024-09-07 15:26:26浏览次数:11  
标签:服务 SpringCloud Consul 可用性 一致性 CP 分区

1. 简介

为什么引入

微服务所在的IP地址和端口号硬编码到订单微服务中,会存在非常多的问题

 

(1)如果订单微服务和支付微服务的IP地址或者端口号发生了变化,则支付微服务将变得不可用,需要同步修改订单微服务中调用支付微服务的IP地址和端口号。

 

(2)如果系统中提供了多个订单微服务和支付微服务,则无法实现微服务的负载均衡功能。

 

(3)如果系统需要支持更高的并发,需要部署更多的订单微服务和支付微服务,硬编码订单微服务则后续的维护会变得异常复杂。

 

所以,在微服务开发的过程中,需要引入服务治理功能,实现微服务之间的动态注册与发现

 

HashiCorp Consul 是一种服务网络解决方案,使团队能够管理服务之间以及跨本地和多云环境和运行时的安全网络连接。Consul 提供服务发现、服务网格、流量管理和网络基础设施设备的自动更新。您可以单独使用这些功能,也可以在单个 Consul 部署中一起使用这些功能。

 2. 面试题 

CAP原理 

最多只能同时较好的满足两个。

 CAP理论的核心是:一个分布式系统不可能同时很好的满足一致性,可用性和分区容错性这三个需求,

因此,根据 CAP 原理将 NoSQL 数据库分成了满足 CA 原则、满足 CP 原则和满足 AP 原则三 大类:

CA - 单点集群,满足一致性,可用性的系统,通常在可扩展性上不太强大。

CP - 满足一致性,分区容忍必的系统,通常性能不是特别高。

AP - 满足可用性,分区容忍性的系统,通常可能对一致性要求低一些。

Eurka原理

AP架构

当网络分区出现后,为了保证可用性,系统B可以返回旧值,保证系统的可用性。

当数据出现不一致时,虽然A, B上的注册信息不完全相同,但每个Eureka节点依然能够正常对外提供服务,这会出现查询服务信息时如果请求A查不到,但请求B就能查到。如此保证了可用性但牺牲了一致性结论:违背了一致性C的要求,只满足可用性和分区容错,即AP

 

 Zookeeper/Consul原理

CP架构

当网络分区出现后,为了保证一致性,就必须拒接请求,否则无法保证一致性,Consul 遵循CAP原理中的CP原则,保证了强一致性和分区容错性,且使用的是Raft算法,比zookeeper使用的Paxos算法更加简单。虽然保证了强一致性,但是可用性就相应下降了,例如服务注册的时间会稍长一些,因为 Consul 的 raft 协议要求必须过半数的节点都写入成功才认为注册成功 ;在leader挂掉了之后,重新选举出leader之前会导致Consul 服务不可用。结论:违背了可用性A的要求,只满足一致性和分区容错,即CP

 

标签:服务,SpringCloud,Consul,可用性,一致性,CP,分区
From: https://blog.csdn.net/2301_79526467/article/details/141973830

相关文章

  • SpringCloud集成ELK
    1、添加依赖<dependency><groupId>net.logstash.logback</groupId><artifactId>logstash-logback-encoder</artifactId><version>6.1</version></dependency>2、在logback-spring.xml中添加配置信息(logback-spring.xml......
  • Open Feign之非SpringCloud方式使用实践
    OpenFeign之非SpringCloud方式使用前言网上对于spring-cloud-starter-openfeign的使用有非常多的说明,此处不再赘述。机缘巧合之下,笔者遇到希望轻量级使用OpenFeign的场景,即项目中并未使用SpringCloud框架、注册中心等服务发现组件,而只是想简单的做远程http请求调用来解耦微-微服......
  • 熔断、限流、降级 —— SpringCloud Hystrix
    概述Hystrix为微服务架构提供了一整套服务隔离、服务熔断和服务降级的解决方案。它是熔断器的一种实现,主要用于解决微服务架构的高可用及服务雪崩等问题Hystrix的特性如下:服务熔断:Hystrix熔断器就像家中的安全阀一样,一旦某个服务不可用,熔断器就会直接切断该链路上的请求,避......
  • Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
    文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录博客园版为您奉上珍贵的学习资源:免费赠送:《尼恩Java面试宝典》持续更新+史上最全+面试必备2000页+面试必备+大厂必备+涨薪必备免费赠送:《尼恩技术圣经+高并发系列PDF》,帮你实现技术自由,完成职业升级,薪......
  • 深入理解Spring Cloud Consul的KV存储与配置中心功能
    深入理解SpringCloudConsul的KV存储与配置中心功能SpringCloudConsul是SpringCloud生态系统中的一个重要组件,用于微服务注册、发现和配置管理。它基于Consul的功能,提供了一种轻量级的服务注册与发现的解决方案,并且支持键值(KV)存储,这使得它可以作为配置中心来管理......
  • SpringCloud-搭建XXL-JOB任务调度平台
    本教程提供了从XXL-JOB平台介绍到具体搭建流程的详细说明,旨在帮助开发者和系统管理员快速理解和部署XXL-JOB任务调度平台。通过SpringCloud集成XXL-JOB任务调度平台,可以使微服务环境中的任务调度更加灵活和高效。整个过程中,调度中心和执行器的正确配置是关键。此外,通过XXL-JOB提供......
  • Java服务端服务发现:Eureka与Consul的故障排查
    Java服务端服务发现:Eureka与Consul的故障排查大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!在微服务架构中,服务发现是实现服务间通信的关键机制。Eureka和Consul是两个广泛使用的服务发现工具。它们都提供了服务注册与发现的功能,但在实际使用过程中......
  • Java服务端服务注册:Consul与Eureka的高级配置
    Java服务端服务注册:Consul与Eureka的高级配置大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!在微服务架构中,服务注册与发现是确保服务之间能够相互通信的关键机制。Consul和Eureka是两种流行的服务注册与发现工具。本文将介绍如何对它们进行高级配置......
  • SpringCloud Gateway鉴权
    参考:https://blog.csdn.net/weixin_43296313/article/details/121126811基于从前的项目:https://www.cnblogs.com/xsj1989/p/18350213在网关项目下创建全局过滤器packagecom.xcg.filters;importcom.auth0.jwt.interfaces.Claim;importcom.auth0.jwt.interfaces.DecodedJWT;......
  • springcloud
    SpringCloudidea微服务项目导入,maven加载过慢方法1方法2简单理解就是将不同功能controller分为两个接口供外部使用......