SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

生活中,最使人疲惫的往往不是道路的遥远,而是心中的郁闷;最使人痛苦的往往不是生活的不幸,而是希望的破灭;最使人颓废的往往不是前途的坎坷,而是自信的丧失;最使人绝望的往往不是挫折的打击,而是心灵的死亡。所以我们要有自己的梦想,让梦想的星光指引着我们走出落漠,走出惆怅,带着我们走进自己的理想。

导读:本篇文章讲解 SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

场景

SpringCloudConfig分布式配置中心介绍与搭建使用以及ConfigClient实现动态刷新配置:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/125053928

在上面实现ConfigClient动态刷新的机制下,是通过post接口调用ConfigClient的方式去进行动态

刷新配置。下面使用Nacos实现配置中心并实现配置动态刷新。

SpringCloudAlibaba中使用Nacos实现服务注册与发现(从实例入手):

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/125177618

在上面实现Nacos作为服务注册中心的基础上,怎样使用Nacos作为配置中心。

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

1、新建子模块cloudalibaba-config-nacos-client3377模块

修改其pom文件,添加nacos-config的依赖

        <!--nacos-config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

除此之外还需要添加服务发现以及web的相关依赖

<?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>SpringCloudDemo</artifactId>
        <groupId>com.badao</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>cloudalibaba-config-nacos-client3377</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <dependencies>
        <!--nacos-config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <!--nacos-discovery-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <!--web + actuator-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
    </dependencies>
</project>

Nacos同springcloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,

拉取配置之后,才能保证项目的正常启动。

springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于application。

所以新建bootstrap.yml配置文件来配置ncaos相关的配置

# nacos配置
server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服务注册中心地址
      config:
        server-addr: localhost:8848 #Nacos作为配置中心地址
        file-extension: yaml #指定yaml格式的配置

然后再新建application.yml,配置环境是开发、测试、产品

spring:
  profiles:
    active: dev # 表示开发环境

新建controller,并添加@RefreshScope注解来支持Nacos的动态刷新功能,并获取配置文件的内容

参考官方说明

SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

package com.badao.springcloudalibabademo.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RefreshScope //支持Nacos的动态刷新功能。
public class ConfigClientController
{
    @Value("${config.info}")
    private String configInfo;

    @GetMapping("/config/info")
    public String getConfigInfo() {
        return configInfo;
    }
}

新建主启动类并添加注解@EnableDiscoveryClient

package com.badao.springcloudalibabademo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;


@EnableDiscoveryClient
@SpringBootApplication
public class NacosConfigClientMain3377
{
    public static void main(String[] args) {
        SpringApplication.run(NacosConfigClientMain3377.class, args);
    }
}

2、启动Nacos,并访问

http://localhost:8848/nacos

点击配置中心,点击加号,新建一个配置文件

SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

 

那么每个服务是怎样找到这个对应的配置文件那?

换句话说,nacos怎样知道你新建的配置文件是属于哪个服务的那?

所以在新建配置文件时会有对应的规则/公式来进行匹配。

比如这里的配置文件的Data ID为nacos-config-client-dev.yaml

SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

 

这个命名是根据官方的说明的公式来

https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html

SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

 

在Nacos Spring Cloud中,dataId的完整格式:

${prefix}-${spring.profiles.active}.${file-extension}

prefix:

默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。

spring.profiles.active :

即为当前环境对应的 profile,详情可以参考 Spring Boot文档。

注意:当 spring.profiles.active 为空时,对应的连接符 – 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}

ile-exetension:

为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。

目前只支持 properties 和 yaml 类型。

修改上面新建配置文件的内容如下

config:
    info: from nacos config center ,nacos-config-client-dev.yaml,version = 1

3、启动上面新建的服务3377,并访问获取配置文件的接口

http://localhost:3377//config/info

SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

 

修改nacos中配置文件内容,此时再访问该接口,可以看到实现了动态刷新

SpringCloudAlibaba中使用Nacos实现配置中心和配置动态刷新

 

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

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/135937.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!