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

本文主要是介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《SpringCloud之consul服务注册与发现、配置管理、配置持久化方式》:本文主要介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,具有很好的参考价值,希望...

前言

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

一、consul是什么?

Consul 是一套开源的分布式服务发China编程现和配置管理系统,由 HashiCorp 公司用 Go 语言开发。

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

作用:

  • 服务发现:提供HTTP和DNS两种发现方式
  • 健康监测:支持多种方式,HTTP、TCP、docker、Shell脚本定制化监控
  • KV存储:Key、Value的存储方式。
  • 多数据中心:Consul支持多数据中心

可视化Web界面

  • consul官网地址:http://www.consul.io
  • spring consul:http://docs.spring.io/spring-cloud-consul/docs/current/reference/html/

二、安装运行consul

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

编程

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

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

最后在 localhost:8500访问

访问结果:

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

三、使用

1、服务发现

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

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

<!--SpringCloud consul discovery -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>China编程;

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

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

    @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端口查看

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

注册成功

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
# /cl编程oud-payment-service-dev/data
# /cloud-payment-service-prod/data

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

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 China编程Consul start= AUTO
@echo.Consul start is OK......success
@pause

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

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

效果:

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

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

总结

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程China编程(www.chinasem.cn)。

这篇关于SpringCloud之consul服务注册与发现、配置管理、配置持久化方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153925

相关文章

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

Spring Boot读取配置文件的五种方式小结

《SpringBoot读取配置文件的五种方式小结》SpringBoot提供了灵活多样的方式来读取配置文件,这篇文章为大家介绍了5种常见的读取方式,文中的示例代码简洁易懂,大家可以根据自己的需要进... 目录1. 配置文件位置与加载顺序2. 读取配置文件的方式汇总方式一:使用 @Value 注解读取配置方式二

一文详解Java异常处理你都了解哪些知识

《一文详解Java异常处理你都了解哪些知识》:本文主要介绍Java异常处理的相关资料,包括异常的分类、捕获和处理异常的语法、常见的异常类型以及自定义异常的实现,文中通过代码介绍的非常详细,需要的朋... 目录前言一、什么是异常二、异常的分类2.1 受检异常2.2 非受检异常三、异常处理的语法3.1 try-

Java中的@SneakyThrows注解用法详解

《Java中的@SneakyThrows注解用法详解》:本文主要介绍Java中的@SneakyThrows注解用法的相关资料,Lombok的@SneakyThrows注解简化了Java方法中的异常... 目录前言一、@SneakyThrows 简介1.1 什么是 Lombok?二、@SneakyThrows

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转