SpringCloud整合Consul的实现
作者:isWulongbo
这篇文章主要介绍了SpringCloud整合Consul的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
下载安装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
上来。
到此这篇关于SpringCloud整合Consul的实现的文章就介绍到这了,更多相关SpringCloud整合Consul内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- SpringCloud2020整合Nacos-Bootstrap配置不生效的解决
- SpringCloud整合Nacos实现流程详解
- es(elasticsearch)整合SpringCloud(SpringBoot)搭建教程详解
- 浅析springcloud 整合 zipkin-server 内存日志监控
- SpringCloud整合分布式服务跟踪zipkin的实现
- SpringBoot2.0整合SpringCloud Finchley @hystrixcommand注解找不到解决方案
- 基于SpringCloud手写一个简易版Sentinel
- SpringCloud微服务之Config知识总结
- SpringCloud服务注册和发现组件Eureka
- SpringCloud实现Eureka服务注册与发现
- spring cloud整合ribbon问题及解决方案