下载安装 Consul
拜访 Consul 官网下载 Consul 的最新版本,我这里是 consul_1.9.1。
这里以 Windows 为例,下载下来是一个 consul_1.9.1_windows_amd64.zip 的压缩包,解压是是一个 consul.exe 的执行文件。
启动 Consul
cd 到对应的目录下,应用 cmd 启动 Consul
cd E:\ 迅雷下载 \consul_1.9.1_windows_amd64
#cmd 启动:consul agent -dev # -dev 示意开发模式运行,另外还有 -server 示意服务模式运行
为了不便期间,能够在同级目录下创立一个 run.bat
脚本来启动,脚本内容如下:
consul agent -dev
pause
启动 run.bat
脚本胜利之后拜访:http://localhost:8500
,能够看到 Consul 的治理界面
springcloud 整合 Consul
因为比较简单在这里咱们就不再新建我的项目了,咱们基于之前的我的项目 SpringCloud 整合 Zookeeper 来做批改。
批改 pom 依赖
咱们只须要把原先的 zookeeper
依赖替换为 consul
依赖即可
<!--springcloud 整合 zookeeper 客户端 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>
</dependency>
<!--springcloud 整合 consul-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
替换后如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent> <artifactId>springcloud-zookeeper</artifactId>
<groupId>com.baba.wlb</groupId>
<version>1.0-SNAPSHOT</version>
</parent> <modelVersion>4.0.0</modelVersion>
<artifactId>springcloud-zookeeper-member</artifactId>
<dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.M7</version>
<type>pom</type>
<scope>import</scope>
</dependency> </dependencies> </dependencyManagement>
<dependencies>
<!--springboot 整合 web 组件 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--springcloud 整合 zookeeper 客户端 -->
<!-- <dependency>-->
<!-- <groupId>org.springframework.cloud</groupId>-->
<!-- <artifactId>spring-cloud-starter-zookeeper-discovery</artifactId>-->
<!-- </dependency>-->
<!--springcloud 整合 consul-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>
</dependencies>
<!-- 留神:这里必须增加,否则各种依赖有问题 -->
<repositories>
<repository> <id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/libs-milestone</url>
<snapshots> <enabled>false</enabled>
</snapshots> </repository> </repositories></project>
批改 yml 配置文件
为了不便切换 zookeeper
和 consul
咱们调整一下 yml 配置即可:
application.yml
文件:
spring:
profiles:
active: consul
application-zk.yml
文件:
## 服务器端口号
server:
port: 7001
##dubbo 注册到注册核心的名称
spring:
application:
name: zk-member
cloud:
zookeeper:
connect-string: 39.102.56.91:2181
application-consul.yml
文件:
## 服务端口号
server:
port: 8501
spring:
application:
## 服务别名 -- 服务注册到 consul 名称
name: consul-member
## 注册核心 consul 地址
cloud:
consul:
host: localhost
port: 8500
discovery:
## consul ip 地址
hostname: 192.168.3.91
启动我的项目
启动 AppMember.java
启动类的注解都为 @EnableDiscoveryClient
。
拜访 http://localhost:8500/ui/dc1/services
能够看到 member
服务注册到 sonsul
上来。