SpringCloudalibaba之Nacos的配置管理

Nacos的配置管理

放个妹子能增加访问量?
在这里插入图片描述

动态配置服务

动态配置服务可以让您以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置。

动态配置消除了配置变更时重新部署应用和服务的需要,让配置管理变得更加高效和敏捷。

配置中心化管理让实现无状态服务变得更简单,让服务按需弹性扩展变得更容易。

前提:

​ 需要搭建一个nacos单机或者集群,按照链接文档搭建

创建配置

这里先创建配置,好在应用集成的时候说明参数释义

  1. 创建命名空间,在命令空间菜单下,点击新建,空间名为nacos-config-example

在这里插入图片描述

  1. 点击创建配置,按照以下图示创建,并点击发布

在这里插入图片描述

这里有个dataId,是应用获取nacos配置文件的唯一标识,匹配规则在应用集成

应用集成

创建nacos-config-example模块

  1. 引入依赖
	<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>
    </dependencies>

spring-boot版本号为2.4.2,nacos-config版本号为2021.1,bootstrap版本号为3.0.3,在父pom中定义,此处不展示

  1. 创建ConfigApplication,此处将controller也写在一块
package cn.axj.config;

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

@RestController
@SpringBootApplication
public class ConfigApplication {
    @Value("${useLocalCache}")
    private boolean useLocalCache;

   /**
     * 测试连接,获取配置信息
     */
    @GetMapping("/config")
    public Object config(){
        return useLocalCache;
    }
    
    public static void main(String[] args) {
        SpringApplication.run(ConfigApplication.class,args);
    }
}

  1. 在resources下创建bootstrap.yml文件,并配置nacos配置中心的相关信息
spring:
  application:
    name: nacos-config-example
  cloud:
    nacos:
      config:
        group: nacos-config-example-group
        namespace: nacos-config-example
        server-addr: 192.168.56.102:8848,192.168.56.104:8848,192.168.56.105:8848
        file-extension: yml
        prefix: ${spring.application.name}

参数释义:

参数名称参数释义参数作用
server-addrnacos的ip地址,集群模式下需要配置所有的节点信息配置nacos机器地址
namespace对应nacos的命名空间,配置的隔离性和安全性
group在配置的时候有个组信息,默认是DEFAULT_GROUP配置的隔离性
file-extension配置文件结束标记,目前只支持yml或者properties获取nacos配置文件的组成部分
prefix配置的前缀,默认是${spring.application.name}可以自定义,可不配置,使用默认

tips: 这里可以看到nacos没有配置usernamepassword可以直接访问到nacos,并获取配置信息。这是因为nacos默认的弱鉴权机制,官方强烈不推荐nacos暴露到公网环境中,如果要暴露到公网环境中,需要自己实现nacos的鉴权插件,实现自己的鉴权逻辑,不然会有巨大的安全风险。

关于应用会从nacos配置中心获取哪一份配置的说明

说明:之所以需要配置 spring.application.name ,是因为它是构成 Nacos 配置管理 dataId字段的一部分。

在 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}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 propertiesyaml 类型。
  1. 启动ConfigApplication,访问localhost:8080/config,看到返回最开始配置的false

在线编辑&动态刷新

在这里插入图片描述

选中nacos-config-example.yml,点击编辑,将useLocalCache配置改成true,并点击发布

在这里插入图片描述

访问localhost:8080/config,看到返回还是最开始配置的false

如何实现动态刷新
  1. 在controller类上面加上SpringCloud的原生注解@RefreshScope,需要动态刷新的controller都需要加上
  2. 在ConfigApplication上面加上@RefreshScope注解
@RestController
@SpringBootApplication
@RefreshScope
public class ConfigApplication {
    ...
}
  1. 重启应用,由于此时,useLocalCache的值已经变成true,所以此时访问localhost:8080/config,会返回true

  2. 将useLocalCache的值改成false,并点击发布,再次访问localhost:8080/config,观察返回值是否同步更新

一键回滚

当动态更新配置的时候,由于错误配置等各种原因,需要将配置还原,nacos提供了历史版本功能。可以直接回滚到想要的版本中去。

  1. 点击历史版本,或者菜单栏点击历史版本模块

在这里插入图片描述

  1. 历史版本界面

在这里插入图片描述

  • 点击详情可以看到当前版本的配置内容
  • 点击对比可以看到当前版本对应上一个版本的变动内容
  • 点击回滚后,点击回滚配置,可以将配置更新到当前版本

监听查询

监听查询有配置和ip的维度。

通过搜索对应的配置信息,可以查询到有哪个ip的机器获取过该配置信息。

在这里插入图片描述

如图所示,nacos-config-example被192.168.56.1获取过。

tips,由于我的nacos(192.168.56.102-105)在虚拟机环境下,所以宿主机ip为192.168.56.1

  • 10
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值