1、consul 简介

  • https://www.consul.io
  • consul是一个可以提供服务发现,健康检查,多数据中心,Key/Value存储等功能的分布式服务框架,用于实现分布式系统的服务发现与配置。与其他分布式服务注册与发现的方案,使用起来也较为简单。Consul用Golang实现,因此具有天然可移植性(支持Linux、Windows和Mac OS X);安装包仅包含一个可执行文件,方便部署。

2、安装consul

下载consul https://www.consul.io/downloads

image.png

2.1 解压

image.png

2.2 当前目录 使用 consul agent -dev 命令 启动

image.png

2.3 http://localhost:8500/ 访问

image.png

2.4 拓展 mac 启动命令

mac 解压文件 当前目录使用命令

./consul agent -dev

3、相关配置

3.1 引入consul依赖

  1. <!--引入consul依赖-->
  2. <dependency>
  3. <groupId>org.springframework.cloud</groupId>
  4. <artifactId>spring-cloud-starter-consul-discovery</artifactId>
  5. </dependency>

3.2 yml 文件

  1. server:
  2. port: 6103
  3. spring:
  4. application:
  5. name: consul-client
  6. cloud:
  7. consul:
  8. host: localhost #注册consul服务的主机
  9. port: 8500 #注册consul服务的端口号

3.3 启动访问 http://localhost:8500/

image.png

3.4、开启consul健康监控

默认情况加consul监控健康是开启的,但是必须依赖健康监控依赖才能正确监控健康状态所以直接启动会显示错误,引入健康监控依赖之后服务正常

引入jar 包

  1. <!-- 健康度监控-->
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-actuator</artifactId>
  5. </dependency>

3.5、 重启

image.png

3.6 关闭健康检查

  1. server:
  2. port: 6103
  3. spring:
  4. application:
  5. name: consul-client
  6. cloud:
  7. consul:
  8. host: localhost #注册consul服务的主机
  9. port: 8500 #注册consul服务的端口号
  10. discovery:
  11. # register-health-check: true # 开启 关闭consul 服务的健康检查[不推荐]
  12. service-name: ${spring.application.name} #指定注册的服务名称 默认就是应用名

3.7 完整 pom.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <parent>
  6. <groupId>org.springframework.boot</groupId>
  7. <artifactId>spring-boot-starter-parent</artifactId>
  8. <version>2.3.5.RELEASE</version>
  9. <relativePath/> <!-- lookup parent from repository -->
  10. </parent>
  11. <groupId>com.morrow</groupId>
  12. <artifactId>springcloud-consul-client-6103</artifactId>
  13. <version>0.0.1-SNAPSHOT</version>
  14. <name>springcloud-consul-client-6103</name>
  15. <description>springcloud-consul-client-6103 project for Spring Boot</description>
  16. <properties>
  17. <java.version>11</java.version>
  18. <spring-cloud.version>Hoxton.SR6</spring-cloud.version>
  19. </properties>
  20. <dependencies>
  21. <dependency>
  22. <groupId>org.springframework.boot</groupId>
  23. <artifactId>spring-boot-starter-web</artifactId>
  24. </dependency>
  25. <dependency>
  26. <groupId>org.springframework.boot</groupId>
  27. <artifactId>spring-boot-starter-test</artifactId>
  28. <scope>test</scope>
  29. </dependency>
  30. <!--引入consul依赖-->
  31. <dependency>
  32. <groupId>org.springframework.cloud</groupId>
  33. <artifactId>spring-cloud-starter-consul-discovery</artifactId>
  34. </dependency>
  35. <!-- 健康度监控-->
  36. <dependency>
  37. <groupId>org.springframework.boot</groupId>
  38. <artifactId>spring-boot-starter-actuator</artifactId>
  39. </dependency>
  40. </dependencies>
  41. <!--全局管理springcloud版本,并不会引入具体依赖-->
  42. <dependencyManagement>
  43. <dependencies>
  44. <dependency>
  45. <groupId>org.springframework.cloud</groupId>
  46. <artifactId>spring-cloud-dependencies</artifactId>
  47. <version>${spring-cloud.version}</version>
  48. <type>pom</type>
  49. <scope>import</scope>
  50. </dependency>
  51. </dependencies>
  52. </dependencyManagement>
  53. <build>
  54. <plugins>
  55. <plugin>
  56. <groupId>org.springframework.boot</groupId>
  57. <artifactId>spring-boot-maven-plugin</artifactId>
  58. </plugin>
  59. </plugins>
  60. </build>
  61. </project>

4、示例代码

springcloud-consul-client-6103