SpringCloud整合Consul

isWulongbo

下载安装Consul

访问Consul 官网下载 Consul 的最新版本,我这里是 consul_1.9.1。

这里以 Windows 为例,下载下来是一个 consul_1.9.1_windows_amd64.zip 的压缩包,解压是是一个 consul.exe 的执行文件。

image.png

启动Consul

cd 到对应的目录下,使用 cmd 启动 Consul

cd E:\迅雷下载\consul_1.9.1_windows_amd64
#cmd启动:
consul agent -dev        # -dev表示开发模式运行,另外还有-server表示服务模式运行

为了方便期间,可以在同级目录下创建一个 run.bat 脚本来启动,脚本内容如下:

consul agent -dev
pause

image.png

启动run.bat 脚本成功之后访问:http://localhost:8500,可以看到 Consul 的管理界面
image.png

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: 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
image.png

访问 http://localhost:8500/ui/dc1/services
image.png

可以看到 member 服务注册到 sonsul 上来。

阅读 389

wulongbo
我的专栏

在人生的头三十年,你培养习惯,后三十年,习惯铸就你

202 声望
16 粉丝
0 条评论
你知道吗?

在人生的头三十年,你培养习惯,后三十年,习惯铸就你

202 声望
16 粉丝
宣传栏