失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > Consul微服务注册与发现

Consul微服务注册与发现

时间:2022-09-26 09:15:43

相关推荐

Consul微服务注册与发现

Consul微服务注册与发现

概念安装与运行服务提供者服务消费者总结:Eureka、Zookeeper、Consul 的异同

概念

1、什么是Consul?

Consul是一套开源的分布式服务发现和配置管理系统,由HashiCorp公司用 go 语言开发。提供了微服务系统中服务治理、配置中心、控制总线等功能。这些功能中的每一个都可以根据乣单独使用,也可以一起使用以构建全方位的服务网络,总之,Consul提供了一种完整的服务网格解决方案。

2、优点:基于 raft 协议,比较简洁;支持健康检查,同时支持HTTP和DNS协议,支持跨数据中心的WAN(广域网)集群,提供图形界面、跨平台:支持Linux、Mac、Windows。

3、 作用:

(1)服务发现:提供HTTP和DNS两种方式发现。

(2)健康监测:支持多种方式,HTTP、TCP、Docker、shell监本定制化。

(3)K-V键值对存储:key-value的存储方式。

(4)多数据中心:Consul支持多数据中心

(5)可视化Web界面

安装与运行

一、windows 版

# 解压后配置环境变量 Path:consul.exe 文件所在目录# 打开 cmd 控制台输入如下指令consul agent -dev# 本地打开consul的浏览器端图形界面localhost:8500

如图所示:

服务提供者

1、引入pom 依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-discovery</artifactId></dependency>

2、写yml配置文件

server:port: 8006spring:application:name: consul-provider-payment# consul 注册中心地址cloud:consul:host: localhostport: 8500discovery:service-name: ${spring.application.name}

3、主启动类

@SpringBootApplication@EnableDiscoveryClientpublic class PaymentMain8006 {public static void main(String[] args) {SpringApplication.run(PaymentMain8006.class, args);}}

4、controller

@RestController@Slf4jpublic class PaymentController {@Value("${server.port}")private String serverPort;@RequestMapping(value = "/payment/consul")public String paymentConsul() {return "springcloud with consul:" + serverPort + "\t" + UUID.randomUUID().toString();}}

服务消费者

1、引入pom 依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-consul-discovery</artifactId></dependency>

2、写yml配置文件

server:port: 80spring:application:name: cloud-consumer-ordercloud:consul:host: localhostport: 8500discovery:service-name: ${spring.application.name}

3、主启动类

@SpringBootApplication@EnableDiscoveryClientpublic class OrderConsulMain80 {public static void main(String[] args) {SpringApplication.run(OrderConsulMain80.class, args);}}

4、配置类

@Configurationpublic class ApplicationContextConfig {@Bean@LoadBalanced //给RestTemplate提供负载均衡能力public RestTemplate getRestTemplate(){return new RestTemplate();}}

5、controller

@RestController@Slf4jpublic class OrderConsulController {public static final String INVOKE_URL = "http://consul-provider-payment";@Resourceprivate RestTemplate restTemplate;@GetMapping(value = "/consumer/payment/consul")public String paymentInfo() {String result = restTemplate.getForObject(INVOKE_URL + "/payment/consul", String.class);return result;}}

6、测试

总结:Eureka、Zookeeper、Consul 的异同

1、CAP原则

地址:/qq_36763419/article/details/120014638

2、Eureka、Zookeeper、Consul 的异同

如果觉得《Consul微服务注册与发现》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。