Nacos配置管理-统一配置管理、配置自动刷新、多环境多服务共享配置

简介: Nacos配置管理-统一配置管理、配置自动刷新、多环境多服务共享配置

一、Nacos统一配置管理


1、在Nacos同添加配置文件



2、在微服务中引入Nacos的配置管理客户端依赖:


        <!--nacos的配置管理依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>


3、在userservice中的resource目录添加一个bootstrap.yml文件,这个文件是引导文件,优先级高于application.yml:


spring:
  application:
    name: userservice
  profiles:
    active: dev #环境
  cloud:
    nacos:
      server-addr: localhost:80 # nacos地址
      config:
        file-extension: yaml  # 文件后缀名


4、在user-service中将pattern.dateformat这个属性注入到UserController中做测试:


@RestController
@RequestMapping("/user")
public class UserController {
    //注入nacos中的配置属性
    @Value("${pattern.dateformat}")
    private String dateformat;
    //编写controller,通过日期格式化器来格式化现在的时间并返回
    @GetMapping("now")
    public String now(){
        return LocalDateTime.now().format(DateTimeFormatter.ofPattern(properties.getDateformat()));
    }
    //...略
}


二、配置自动刷新


Nacos中的配置文件变更后,微服务无需重启就可以感知,不过需要通过下面两种配置实现:


方式一:在@Value注入的变量所在类上添加注解@RefreshScope


@Slf4j
@RestController
@RequestMapping("/user")
@RefreshScope
public class UserController {
    //注入nacos中的配置属性
    @Value("${pattern.dateformat}")
    private String dateformat;


方式二:使用@ConfigurationProperties注解


@Data
@Component
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {
    private String dateformat;
}


注意事项:


不是多有的配置都适合放到配置中心,维护起来比较麻烦


建议将一些关键参数,需要运行时调整的参数放在nacos


三、多环境配置共享


微服务启动时会从nacos读取多个配置文件:


[spring.application.name]-[spring.profiles.active].yaml,例如:userservice-dev.yaml


[spring.appliction.name].yaml,例如:userservice.yaml


无论profile如何,[spring.appliction.name].yaml这个文件一定会加载,因此多环境共享配置可以写入这个文件



多种配置的优先级:



四、多服务共享配置


不同微服务之间可以共享配置文件,通过下面的两种方式来指定


方式一:


spring:
  application:
    name: userservice
  profiles:
    active: dev #环境
  cloud:
    nacos:
      server-addr: localhost:80 # nacos地址
      config:
        file-extension: yaml  # 文件后缀名
        shared-configs: # 多服务间共享的配置列表
         -datald: common.yaml # 要共享的配置文件id


方式二:


spring:
  application:
    name: userservice
  profiles:
    active: dev #环境
  cloud:
    nacos:
      server-addr: localhost:80 # nacos地址
      config:
        file-extension: yaml  # 文件后缀名
        extends-configs: # 多服务间共享的配置列表
         -datald: extend.yaml # 要共享的配置文件id


多种配置的优先级:


目录
相关文章
|
7天前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
|
22天前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评。然而,“客户端不发送心跳检测”是使用中常见的问题之一。本文详细探讨了该问题的原因及解决方法,包括检查客户端配置、网络连接、日志、版本兼容性、心跳检测策略、服务实例注册状态、重启应用及环境变量等步骤,旨在帮助开发者快速定位并解决问题,确保服务正常运行。
44 5
|
1月前
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
126 10
|
22天前
|
Dubbo Cloud Native 应用服务中间件
阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。
在云原生时代,微服务架构成为主流。阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。示例代码展示了如何在项目中实现两者的整合,通过 Nacos 动态调整服务状态和配置,适应多变的业务需求。
34 2
|
1月前
|
网络安全 Nacos 开发者
Nacos作为流行的微服务注册与配置中心,“节点提示暂时不可用”是常见的问题之一
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,“节点提示暂时不可用”是常见的问题之一。本文将探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务的正常运行。通过检查服务实例状态、网络连接、Nacos配置、调整健康检查策略等步骤,可以有效解决这一问题。
36 4
|
5月前
|
Java Nacos 数据库
使用 nacos 搭建注册中心及配置中心
使用 nacos 搭建注册中心及配置中心
104 5
|
5月前
|
NoSQL Java Nacos
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
170 3
|
1月前
|
负载均衡 应用服务中间件 Nacos
Nacos配置中心
Nacos配置中心
75 1
Nacos配置中心
|
1月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,实际使用中常遇到“客户端不发送心跳检测”的问题。本文深入探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务正常运行。通过检查客户端配置、网络连接、日志、版本兼容性、心跳策略、注册状态、重启应用和环境变量等步骤,系统地排查和解决这一问题。
50 3
|
1月前
|
安全 Nacos 数据库
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改。本文详细探讨了这一问题的原因及解决方案,包括限制公网访问、使用HTTPS、强化数据库安全、启用访问控制、监控和审计等步骤,帮助开发者确保服务的安全运行。
44 3