构建微服务架构(Consul篇)
B 站视频:https://www.bilibili.com/video/BV18E411x7eT?from=search&seid=13583080742381804215
原 Blog 笔记文档:https://blog.csdn.net/u011863024/article/details/114298270
本篇文章大部分图片用到了参考的 blog 笔记中的图片。
本人代码下载:下载
Consul 简介
Consul 是一个服务网格解决方案,它提供了一个功能齐全的控制平面,具有服务发现、配置和分段功能。这些特性中的每一个都可以根据需要单独使用,也可以一起用于构建全服务网格。Consul 需要一个数据平面,并支持代理和本机集成模型。Consul 与一个简单的内置代理,使一切工作的开箱即用,但也支持第三方代理集成,如 Envoy。
Consul 是一套开源的分布式服务发现和配置管理系统,由 HashiCorp 公司用 Go 语言开发。
提供了微服务系统中的服务治理、配置中心、控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,总之 Consul 提供了一种完整的服务网格解决方案。
它具有很多优点。包括:基于 raft 协议,比较简洁;支持健康检查,同时支持 HTTP 和 DNS 协议支持跨数据中心的 WAN 集群提供图形界面跨平台,支持 Linux、Mac、Windows。
能干嘛?
服务发现 - 提供 HTTP 和 DNS 两种发现方式。
健康监测 - 支持多种方式,HTTP、TCP、Docker、Shell 脚本定制化
KV存储 - Key、Value 的存储方式
多数据中心 - Consul 支持多数据中心
可视化 Web 界面
1. 安装并运行 Consul
1.1. 下载地址:https://www.consul.io/downloads
1.2. 安装 Consul
Consul 下载下来后解压就一个 exe 可执行文件。
1.3. 在 CMD 运行窗口运行 Consul
1 | consul.exe agent -dev |
1.4. 运行成功后就可以在 http://localhost:8500
2. 支付微服务注册进Consul
2.1 创建父工程 springcloud2021
2.2 springcloud2021 父工程 pom.xml 代码如下
1 | <?xml version="1.0" encoding="UTF-8"?> |
2.3 新建 Module 支付服务 cloud-provider-payment8006
2.4 cloud-provider-payment8006 项目 pom.xml 文件如下
1 | <?xml version="1.0" encoding="UTF-8"?> |
2.5 cloud-provider-payment8006 项目 application.yml 文件如下
1 | # consul服务端口号 |
2.6 cloud-provider-payment8006 项目 主启动类 如下
1 | package com.sevattal.springcloud; |
2.7 cloud-provider-payment8006 项目 业务类Controller
1 | package com.sevattal.springcloud.controller; |
2.8 验证测试
http://localhost:8006/payment/consul
http://localhost:8500 - 会显示 consul-provider-payment
3. 服务消费者注册进Consul
3.1 新建Module消费服务order80 - cloud-consumerconsul-order80
3.2 cloud-consumerconsul-order80 项目 pom.xml 文件如下
1 | <?xml version="1.0" encoding="UTF-8"?> |
3.3 cloud-consumerconsul-order80 项目 application.yml 文件如下
1 | # consul服务端口号 |
3.4 cloud-consumerconsul-order80 项目 主启动类 文件如下
1 | import org.springframework.boot.SpringApplication; |
3.5 cloud-consumerconsul-order80 项目 配置Bean
1 | package com.sevattal.springcloud.config; |
3.6 cloud-consumerconsul-order80 项目 Controller
1 | package com.sevattal.springcloud.controller; |
3.7.验证测试
运行 consul,cloud-providerconsul-payment8006,cloud-consumerconsul-order80
http://localhost:8500/ 主页会显示出 consul,cloud-providerconsul-payment8006,cloud-consumerconsul-order80三服务。