唯能极于情,故能极于剑
有问题或错误请及时联系小编或关注小编公众号 “CodeCow”,小编一定及时回复和改正,期待和大家一起学习交流
此文由四部分组成(Consul简介、安装、实操、总结),别着急,慢慢来
一、Consul
- 官网:Consul 是一种服务网格解决方案,提供具有服务发现,配置中心和分段功能的全功能控制平面。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建完整的服务网格 …总之,Consul提供了一种完整的服务网格解决方案
- 自己:Consul 就是一套开源的分布式服务发现和配置管理系统,由HashiCorp公司用 Go 语言开发
小编就不多 BB 先来张图 压压惊
可以发现,Consul 这哥们 干掉了 Eureka,你说他能干嘛 ^ _ ^ , 只不过 Consul 是CP(数据一致性)、Eureka 是 AP(高可用性)
看看 Consul 这哥们有啥技能 :
- KV存储:Key、Value的存储方式
- 服务发现:提供HTTP/DNS两种发现方式
- 健康检测:支持多种方式,HTTP、TCP、Docker、shell脚本定制化
- 多数据中心:Consul支持多数据中心
- 可视化界面
1.3、Consul 怎么玩 ? :
- Consul中文网:https://www.springcloud.cc/spring-cloud-consul.html 好男人必备网站,哈哈
不会玩的朋友别着急,看下面小编娓娓道来
二、Consul 安装
1、进入consul官网下载地址:https://www.consul.io/downloads.html
2、根据自己需要下载对应安装包
3、把安装包解压,解压后生成一个 consul.exe 文件
4、在含有consul.exe目录文件夹下(就是第二部解压目录) 输入 cmd ,然后空格,进入命令行模式
5、输入 consul --version 查看当前 Consul版本(正常显示为:Consul v1.x.x)
6、输入 consul agent -dev 启动 Consul
7、进入浏览器,在地址栏输入:localhost:8500 出现下面界面代表成功 ^ _ ^
三、Consul 实操
前两个步骤完事了,不来点 硬核 咋行呢,下面小编就结合实际开发和大家聊聊
1、首先导包
<!-- 服务注册与发现 consul -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
<!-- 监控 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
若还有其他需要可自行导包
2、改 YML 配置文件
server: port: 8006 //端口号 spring: application: name: cloud-payment-service //服务名 cloud: consul: host: localhost //consul的IP(可以改成自己电脑ip) port: 8500 //consul启动端口默认8500 discovery: service-name: ${spring.application.name} prefer-ip-address: true //不写这个配置,在docker下的consul里面健康检查会失败 healthCheckInterval: 5s //健康检查频率 port: ${server.port} //注册服务所在端口 //================================================================================ //下面根据自己需要添加 datasource: url: jdbc:mysql://localhost:3306/spring_cloud_2020?characterEncoding=utf-8&useSSL=false&serverTimezone=UTC username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver type: com.alibaba.druid.pool.DruidDataSource mybatis-plus: typeAliasesPackage: top.msxdlb.springcloud.bean.entity //实体扫描,多个package用逗号或者分号分隔
3、添加主启动类
@SpringBootApplication // springboot 注解 @EnableDiscoveryClient // 作用:能够让注册中心发现,并扫描到该服务 public class ConsulMain8006 { public static void main(String[] args) { SpringApplication.run(ConsulMain8006.class, args); } }
4、启动服务,可以看到 Consul 多出一个 cloud-payment-service 服务
朋友,这顿 SAO 操作 还可以吧,哈哈,加油 ^ _ ^
四、总结
这是 SpringCloud 的 Consul 篇,后续小编会从 “OpenFeign、Hystrix、Gateway …...” 等坚持以博客的方式来分享自己对SpringCloud 的理解,并从不同角度和大家分享工作心得,并且含有相关Demo,最终小编会发布到GitHub上,供大家下载、分享、交流、指正,下面是源码地址:
GitHub:https://github.com/msxdlb/Spring-Cloud-2020
有问题或错误请及时联系小编或关注小编公众号 “CodeCow”,小编一定及时回复和改正 啦
《 合抱之木,生于毫末 》 别急,慢慢来
2020/04/15 午后