下载安装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 -devpause

启动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配置文件

为了不便切换 zookeeperconsul 咱们调整一下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: 8501spring:  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 上来。