当前位置: 代码网 > it编程>编程语言>Java > SpringCloud之consul服务注册与发现、配置管理、配置持久化方式

SpringCloud之consul服务注册与发现、配置管理、配置持久化方式

2025年03月24日 Java 我要评论
前言老牌注册中心eureka停更运维,新型的consul、nacos崛起,本文介绍consul服务一、consul是什么?consul 是一套开源的分布式服务发现和配置管理系统,由 hashicorp

前言

老牌注册中心eureka停更运维,新型的consul、nacos崛起,本文介绍consul服务

一、consul是什么?

consul 是一套开源的分布式服务发现和配置管理系统,由 hashicorp 公司用 go 语言开发。

提供了微服务系统中的服务治理、配置中心、控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,总之consul提供了一种完整的服务网格解决方案。它具有很多优点。包括: 基于 raft 协议,比较简洁; 支持健康检查, 同时支持 http 和 dns 协议 支持跨数据中心的 wan 集群 提供图形界面 跨平台,支持 linux、mac、windows

作用:

  • 服务发现:提供http和dns两种发现方式
  • 健康监测:支持多种方式,http、tcp、docker、shell脚本定制化监控
  • kv存储:key、value的存储方式。
  • 多数据中心:consul支持多数据中心

可视化web界面

二、安装运行consul

下载地址:http://developer.hashicorp.com/consul/install

下载完成后只有一个.exe文件,在该目录下打开cmd,输入 consul agent -dev 使用开发者模式启动consul

最后在 localhost:8500访问

访问结果:

三、使用

1、服务发现

将微服务注册到consul服务中心中统一管理

1)在需要注册的服务的pom文件中引入依赖:

<!--springcloud consul discovery -->
<dependency>
    <groupid>org.springframework.cloud</groupid>
    <artifactid>spring-cloud-starter-consul-discovery</artifactid>
</dependency>

注意:引入该依赖的同时也引入了loadbalancer(负载均衡),若使用的远程调用方式为resttemplate,需要在创建resttemplate的配置类中对应bean的位置加上@loadbalanced注解,支持负载均衡

    @bean
    @loadbalanced //按服务名称调用时默认负载均衡 要加上该注解支持负载均衡
    public resttemplate resttemplate(){
        return new resttemplate();
    }

2)配置yaml

spring:
application:
name: cloud-consumer-order
cloud:
consul:
port: 8500
host: localhost
discovery:
prefer-ip-address: true #优先使用服务ip进行注册
service-name: ${spring.application.name}

3)主启动类添加注解:@enablediscoveryclient //**服务注册和发现

4)启动主启动类,访问8500端口查看

注册成功

2、配置管理

通用配置配置在consul,每个服务从consul获取配置,也可接受动态刷新

1)服务端加入依赖,调用端不切换配置环境可以不配置到consul

<!--springcloud consul config-->
<dependency>
    <groupid>org.springframework.cloud</groupid>
    <artifactid>spring-cloud-starter-consul-config</artifactid>
</dependency>
<dependency>
    <groupid>org.springframework.cloud</groupid>
    <artifactid>spring-cloud-starter-bootstrap</artifactid>
</dependency>

2)新增配置文件bootstrap.yml

  • applicaiton.yml是用户级的资源配置项
  • bootstrap.yml是系统级的,优先级更加高

spring cloud会创建一个“bootstrap context”,作为spring应用的`application context`的父上下文。初始化的时候,`bootstrap context`负责从外部源加载配置属性并解析配置。这两个上下文共享一个从外部获取的`environment`。

`bootstrap`属性有高优先级,默认情况下,它们不会被本地配置覆盖。 `bootstrap context`和`application context`有着不同的约定,所以新增了一个`bootstrap.yml`文件,保证`bootstrap context`和`application context`配置的分离。

application.yml文件改为bootstrap.yml,这是很关键的或者两者共存

因为bootstrap.yml是比application.yml先加载的。bootstrap.yml优先级高于application.yml

  • bootstrap.yml:
spring:
application:
name: cloud-payment-service
####spring cloud consul for service discovery
cloud:
consul:
host: localhost
port: 8500
discovery:
service-name: ${spring.application.name}
config:
profile-separator: '-' # default value is ",",we update '-'
format: yaml

3)在consul中创建配置文件

以config文件夹开始,data文件结束,中间文件夹以服务名称-配置环境命名 (不写为默认环境)

# config/cloud-payment-service/data
# /cloud-payment-service-dev/data
# /cloud-payment-service-prod/data

4)动态刷新

在主启动类上加入 @refreshscope 注解,这样在consul中更改配置后,响应配置会在服务端刷新

四、数据持久化

问题:我们配置的配置文件,当consul服务退出后就消失了,要将配置的文件持久化到本地,并开机的时候自动启动consul服务

1、在consul安装目录新建一个mydata文件夹存放配置的数据

2、新建一个consul_start.txt文件

文件内容:

其中写明consul.exe文件位置和刚创建的mydata文件夹位置。其中mydata后要有空格

@echo.服务启动......
@echo off
@sc create consul binpath= "d:\wtp\software\cloud\consul\consul.exe agent -server -ui -bind=127.0.0.1 -client=0.0.0.0 -bootstrap-expect 1 -data-dir d:\wtp\software\cloud\consul\mydata "
@net start consul
@sc config consul start= auto
@echo.consul start is ok......success
@pause

3、文件 consul_start.txt 保存后后缀改为.bat

4、以管理员身份运行 consul_start.txt

效果:

总结

本文介绍了consul的安装、使用、持久化。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com