Springcloud - Consul

本文详细介绍了Consul的基础概念,包括其服务发现、健康检查和key/value存储等功能,对比了与Eureka的区别,着重讲解了Consul的强一致性特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Consul基础概念

Consul是一个分布式高可用系统,作为一个整体在微服务架构中提供服务注册和服务配置的工具。Spring Cloud Consul 项目是针对Consul的服务治理实现。

特性:
1、服务发现
2、健康检查
3、key/value 存储
4、多数据中心

工作原理
在这里插入图片描述
1、当 Producer 启动的时候,会向 Consul 发送一个 post 请求,告诉 Consul 自己的 IP 和 Port
2、Consul 接收到 Producer 的注册后,每隔10s(默认)会向 Producer 发送一个健康检查的请求,检验Producer是否健康
3、当 Consumer 发送 GET 方式请求 /api/address 到 Producer 时,会先从 Consul 中拿到一个存储服务 IP 和 Port 的临时表,从表中拿到 Producer 的 IP 和 Port 后再发送 GET 方式请求 /api/address
4、该临时表每隔10s会更新,只包含有通过了健康检查的 Producer。

Consul和Eureka的区别

1、一致性 Consul强一致性(CP)

  • 服务注册相比Eureka会稍慢一些。因为Consul的raft协议要求必须过半数的节点都写入成功才认 为注册成功。
  • Leader挂掉时,重新选举期间整个consul不可用。保证了强一致性但牺牲了可用性。

2、Eureka保证高可用和最终一致性(AP)

  • 服务注册相对要快,因为不需要等注册信息replicate到其他节点,也不保证注册信息是否 replicate成功。
  • 当数据出现不一致时,虽然A, B上的注册信息不完全相同,但每个Eureka节点依然能够正常对外提 供服务,这会出现查询服务信息时如果请求A查不到,但请求B就能查到。如此保证了可用性但牺牲了一致性。
### Spring Cloud Consul Discovery 使用说明 `spring-cloud-starter-consul-discovery` 是 Spring Cloud 提供的一个模块,用于实现基于 Consul 的服务注册与发现功能。以下是该依赖的使用方法及相关配置示例。 #### 添加 Maven 依赖 为了启用 `spring-cloud-starter-consul-discovery` 功能,在项目的 `pom.xml` 文件中需引入以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-consul-discovery</artifactId> <version>2.0.1.RELEASE</version> </dependency> ``` 此依赖允许应用程序自动向 Consul 注册自己并能够通过 Consul 发现其他服务[^1]。 #### 配置文件设置 (application.yml 或 application.properties) 在 Spring Boot 应用程序的配置文件中,需要指定 Consul 的连接信息以及服务的基本属性。下面是一个典型的 YAML 配置示例: ```yaml spring: application: name: my-service-name # 定义服务名称 cloud: consul: host: localhost # Consul Server 地址 port: 8500 # Consul Server 端口 discovery: register: true # 是否注册到 Consul,默认为 true heartbeat: enabled: true # 启用心跳检测机制 ``` 上述配置会告诉应用将其自身注册至本地运行的 Consul 实例,并开启心跳监测以保持服务状态更新[^2]。 #### 自定义元数据传递给 Consul 如果希望将额外的信息随同服务一起注册,则可以通过 `metadata` 字段完成这一操作: ```yaml spring: cloud: consul: discovery: instance-id: ${spring.application.name}:${random.value} # 设置实例 ID tags: tag1,tag2 # 可选标签列表 metadata: version: v1 # 版本号或其他自定义字段 ``` 这些附加的数据可以在后续的服务调用过程中被消费者读取利用。 #### 主类上的注解声明 确保主启动类上有 `@EnableDiscoveryClient` 或者更通用形式的 `@EnableEurekaClient` 注解(尽管名字里有 Eureka,但它同样适用于 Consul)。这一步骤激活了客户端对于服务治理的支持能力。 ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @SpringBootApplication @EnableDiscoveryClient public class MyServiceApplication { public static void main(String[] args) { SpringApplication.run(MyServiceApplication.class, args); } } ``` 以上即完成了基本的服务端和服务消费者的搭建工作流程[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值