Consul是一套开源的分布式服务发现和配套的管理系统(go语言开发的)。
提供了微服务系统中的服务治理、配置中心、控制总线等功能。这些功能可以根据需要单独使用,也可以一起使用以构建全方位的服务网络。
优点:基于raft协议,比较简洁;支持健康检查,同时支持HTTP和DNS协议 支持跨数据中心的WAN集群 提供图形界面 跨平台
1. Consul 的安装与启动
首先从官网下载,解压后windows版本的是一个可执行的文件。教程上说双击就可看版本,我没有成功。
在consul.exe
目录下运行cmd,然后执行consul --version
命令,可查看版本信息;
执行consul agent -dev
运行consul。consul的可视化页面访问路径为http://localhost:8500
至此,一个微服务的注册中心已经启动完毕;
2. 将一个服务提供者注册到consul中
- 服务提供者的配置:只需将pom文件中添加consul的依赖即可
<!--Springboot consul - server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
- 在application.yml文件中配置端口,consul的注册地址以及对外暴露的服务名称
###consul服务端口号
server:
port: 8006
spring:
application:
name: consul-provider-payment
###consul注册中心地址
cloud:
consul:
host: localhost
port: 8500
discovery:
#hostname: 127.0.0.1
service-name: ${spring.application.name}
- 在启动类上添加注解
@EnableDiscoveryClient
- 启动服务提供者,访问consul可视化页面会发现服务已经注册在了consul上
3.将一个消费者注册到consul中
- 在pom文件中添加consul依赖
<!--Springboot consul - server-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
- 在application.yml中配置服务的端口,服务名称等信息
###consul端口号
server:
port: 90
spring:
application:
name: cloud-consumer-order
###consul注册中心地址
cloud:
consul:
host: localhost
discovery:
port: 8500
service-name: ${spring.application.name}
- 写主启动类–加注解
@EnableDiscoveryClient
- 配置bean:
将spring容器中注入RestTemplate,用于调用consul服务上的消费者;
也可以用Fegin 或者Ribbon调用
- 写业务调用consul上面的服务提供者
- 启动消费者服务,会发现consul可视化页面上又多了一个服务,
但我这个有红叉子,不知道哪里有问题