【SpringCloud】03-服务注册与发现-Consul

语雀原文链接

Consul简介

Consul(Go语言编写)是一套开源的分布式服务发现和配置管理系统

提供了微服务系统中的服务治理、配置中心、控制总线等功能,这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,总之consul提供了一种完整的服务网格解决方案

主要功能:服务注册与发现、健康检查、键值对存储、安全加固,多数据中心;

安装并运行Consul

官方下载后运行exe文件
cmd:consul agent-dev即可查看版本信息,查看是否安装成功
访问localhost:8500即可进入consul前端图像化界面

在这里插入图片描述

服务提供者

新建Module支付服务provider8006

  1. 修改pom文件(引入Consul依赖)
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-cloud-starter-web</artifactId>
</dependency>
  1. 修改yaml文件

  2. 在这里插入图片描述

  3. 添加主启动类(注意这里需要@EnableDiscoveryClient注解)

  4. 创建一个访问后返回ServerPort的Controller;

  5. 启动8006服务,访问后返回ServerPort

服务消费者

新建Module消费服务80
maven依赖,主启动类yml文件和之前一样,Consul端口填上面的8500(即yml文件只改项目端口)
然后编写RestConfig配置文件,对RestConfig进行配置,和之前一样;
编写Controller文件,使用RestTemplate访问服务者的地址;

最后进行测试

三个注册中心异同点

都可以集成SpringCloud

组件名语言CAP(主要保证)服务健康检查对外暴露接口
EurekaJavaAP(高可用)可配支持HTTP
ConsulGoCP(数据一致)支持HTTP/DNS
ZookeeperJavaCP支持客户端

CAP理论:

C:Consistency(强一致性)
A:Availability(可用性)
P:Partition tolerance(分区容错性)
CAP理论关注的力度是数据

Eureka注重高可用性(AP):服务一会宕机不会立马删除,会留着
Consul/zookeeper注重数据一致性(CP):当网络分区之后,为了保证一致性,就必须拒接请求,否则无法保证一致性

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

PoJo123

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值