当前位置: 首页 > article >正文

SpringBoot使用Nacos进行application.yml配置管理

Nacos是阿里巴巴开源的一个微服务配置管理和服务发现的解决方案。它提供了动态服务发现、配置管理和 服务管理平台。Nacos的核心功能包括服务发现、配置管理和动态服务管理,使得微服务架构下的服务治理 变得简单高效。

Nacos的设计基于服务注册与发现、配置管理、动态服务管理等核心功能,通过简单的API和配置,实现了服 务的注册与发现、配置的集中管理和动态更新。Nacos使用Raft协议保证配置的一致性,同时支持多种配置 格式,如properties、yaml等。

目录

一、准备

二、nacos管理application.yml配置

1.nacos上新建命令空间和新建配置

2.SpringBoot项目配置改造

pom文件引入依赖

新建bootstrap.yml文件

原yml文件改造

3.启动类注解

4.使用配置

5.测试


一、准备

首先需要在本地电脑上进行Nacos服务部署,默认端口是8848,部署成功之后,就可以去浏览器输入localhost:8848进入nacos管理平台。

二、nacos管理application.yml配置

1.nacos上新建命令空间和新建配置

首先,新建命名空间(如已存在则忽略),注意:命名空间ID可不填,不填则自动生成:

然后,进到nacos的管理页面,在Nacos控制台的左侧导航栏进入配置列表,转到“配置管理”页面,点击“+”来添加一个新的配置。

  • Data ID:统一按照这个格式来: 服务名 - 环境 . 后缀名。主要是因为后面要导入的bootstrap.yaml Spring默认的读取格式就是这样的。
  • Group:分组可以自定义,没有需求可以选择默认分组DEFAULT_GROUP。
  • 命名空间:设置的命名空间ID。
  • 配置格式:yaml。

在配置内容区域,输入你想要暴露给Spring Boot应用的配置信息。可以从SpringBoot获取yml配置信息,将需要配置到config的信息复制配置到配置内容中。

至此,nacos侧配置项已完成,接下来进行SpringBoot项目配置改造。

2.SpringBoot项目配置改造

pom文件引入依赖

首先修改Spring Boot项目的pom.xml文件,在pom.xml文件中添加Nacos Config和Nacos Discovery的依赖。

<!--nacos配置管理依赖-->
<dependencies>  
    <!-- Nacos Config -->  
    <dependency>  
        <groupId>com.alibaba.cloud</groupId>  
        <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>  
        <version>2021.1</version>  
    </dependency>  
    <!-- Nacos Discovery -->  
    <dependency>  
        <groupId>com.alibaba.cloud</groupId>  
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>  
        <version>2021.1</version>  
    </dependency>  
</dependencies>
<!--spring cloud从2021.0.5版本起,Spring Cloud将不再默认启用bootstrap,需要手动添加依赖。不引入bootstrap.properties/yml不生效-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
新建bootstrap.yml文件

Spring引入了一种新的配置文件:bootstrap.yaml。它的读取流程如下:启动项目 --> 读取bootstrap.yaml文件 --> 找到nacos中,对应的配置文件 --> 读取本地 application.yaml文件 —> 创建容器 加载bean …

因此,我们需要在bootstrap.yml文件中配置Nacos服务器地址和命名空间等信息,在spring中nacos配置中心的配置前缀是spring.cloud.nacos.config。

spring:  
  application:  
    name: demo-app  
  cloud:  
    nacos:  
      discovery:  
        server-addr: localhost:8848 # Nacos服务地址  
        namespace: your-namespace-id # Nacos命名空间ID  
      config:  
        server-addr: localhost:8848 # Nacos作为配置中心地址  
        namespace: your-namespace-id # Nacos命名空间ID  
        group: your-group # 配置分组名称  
        data-id: your-data-id # 配置ID,通常与spring.application.name相同  
        extension-configs:  
          - data-id: another-data-id # 另一个配置ID  
            group: ANOTHER_GROUP # 另一个配置分组名称
            refresh: true  
        file-extension: yaml # 配置文件格式,默认为properties

或在bootstrap.properties文件中配置Nacos服务器地址和命名空间等信息

# bootstrap.properties  
spring.cloud.nacos.config.server-addr=127.0.0.1:8848  
spring.cloud.nacos.config.namespace=your-namespace  
spring.cloud.nacos.config.group=DEFAULT_GROUP  
spring.cloud.nacos.config.data-id=your-data-id  
spring.cloud.nacos.config.extension-configs[0].data-id=another-data-id  
spring.cloud.nacos.config.extension-configs[0].group=ANOTHER_GROUP  
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

然后,新建两个文件bootstrap-dev.yaml和bootstrap-prod.yaml,文件内容如下,两个文件内容格式是一样的。

spring:  
  cloud:  
    nacos:  
      discovery:  
        server-addr: localhost:8848 # Nacos服务地址  
        namespace: your-namespace-id # Nacos命名空间ID  
        group: your-group # 配置分组名称  
      config:  
        server-addr: localhost:8848 # Nacos作为配置中心地址  
        namespace: your-namespace-id # Nacos命名空间ID  
        group: your-group # 配置分组名称  

在Nacos的配置中,discovery和config是两个核心组件,它们各自承担着不同的职责。

(1)Discovery(服务发现):

Discovery的主要作用是实现服务的自动注册与发现。当服务提供者启动后,它会自动将自己的服务信息注册到Nacos中。而服务消费者则可以通过Nacos查询和发现可用的服务提供者。这样,服务消费者就能够动态地获取到服务提供者的网络位置(如IP和端口),从而实现服务的调用。

服务发现在微服务架构中非常重要,因为它允许服务之间动态地相互发现和通信,而无需硬编码服务地址。这使得服务能够更灵活地部署和扩展,同时也提高了系统的可用性和容错性。

(2)Config(配置管理):

Config的主要作用是实现配置信息的集中管理和动态更新。在微服务架构中,通常会有许多服务共享一些公共的配置信息,如数据库连接信息、缓存配置等。Config允许将这些配置信息统一存储在Nacos中,并通过配置中心进行管理和分发。当配置信息发生变化时,Config能够实时地将最新的配置推送给服务消费者,从而实现配置的动态更新。

配置管理在微服务架构中同样非常重要,因为它允许开发人员在不重启服务的情况下更新配置信息。这大大提高了系统的灵活性和可维护性,同时也降低了运维成本。

(3)区别:

  • 服务发现(Discovery) 专注于服务的注册与发现,解决的是服务之间的通信问题。它使得服务能够动态地发现和调用其他服务,而无需硬编码服务地址。
  • 配置管理(Config) 专注于配置信息的集中管理和动态更新,解决的是配置信息的共享和更新问题。它允许开发人员在不重启服务的情况下实时更新配置信息,从而提高了系统的灵活性和可维护性。
原yml文件改造

可以保留程序启动端口。

server:
    port:1839

3.启动类注解

在Spring Boot启动类上添加 @EnableDiscoveryClient 和 @EnableConfigServer 注解,开启服务发现和配置管理功能。

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

4.使用配置

在Spring Boot应用中,可以直接通过 @Value 或 @ConfigurationProperties 注解注入Nacos中的配置。@ConfigurationProperties和@Value注解用于获取配置文件中的属性定义并绑定到Java Bean或属性中

通过@Value(“ x x x x ” ) 可以获取属性文件中对应的值,但是如果属性文件中没有这个属性,则会报错。可以通过赋予默认值解决这个问题,如 @ V a l u e ( “ {xxxx}”)可以获取属性文件中对应的值,但是如果属性文件中没有这个属性,则会报错。可以通过赋予默认值解决这个问题,如@Value(“ xxxx)可以获取属性文件中对应的值,但是如果属性文件中没有这个属性,则会报错。可以通过赋予默认值解决这个问题,如@Value({xxxx:yyyy}”)。

@ConfigurationProperties注解对属性绑定遵循relaxed bind rule【暂且翻译为松散绑定规则】,并不需要精确匹配。所谓的宽松绑定原则是指:并不是 JavaBean 中的属性必须要和配置文件中的一致才能绑定数据,context-path 也能绑定到 contextPath 属性上。比如对属性【app.username】,通过【app.userName】、【app.user-name】、【app.user_name】、【app.USER_NAME】、【app.USER-NAME】等都可匹配,我们可理解为模糊匹配。

@RestController
public class ConfigController {
	@Value("${your.config.key}")
	private String configValue;
	
	@GetMapping("/config")
	public String getConfig() {
		return configValue;
	}
}

@Data  // 需要提供默认的构造函数,以及get/setter方法
@ConfigurationProperties("my.service")
public class MyProperties {
    // 我们可以简单地用一个值初始化一个字段来定义一个默认值
    private boolean enabled = true;

    private InetAddress remoteAddress;

    private final Security security = new Security();

    @Data
    public static class Security {
        private String username;

        private String password;
        // 如果这个属性配置的话,默认是“USER”
        private List<String> roles = new ArrayList<>(Collections.singleton("USER"));

    }
}

在配置文件中进行如下配置,

my:
  service:
    enabled: true
    remoteAddress: 127.0.0.1
    security:
     username: csx
     password: passwoed
     roles:
       - role1
       - role2
your:
    config:
        key:ccvvv

5.测试

最后,可以尝试启动项目程序,看看是否能启动成功。如果启动成功则说明成功了。

通过整合Nacos,Spring Boot项目能够轻松实现配置的动态管理和服务的自动发现。Nacos的简单易用和强大的功能使其成为微服务架构中不可或缺的一部分。通过本文的介绍和示例代码,读者应该能够掌握Spring Boot与Nacos的集成方法,并在实际项目中高效利用Nacos进行服务配置管理。


http://www.kler.cn/a/463280.html

相关文章:

  • vscode代码AI插件Continue 安装与使用
  • 解決當前IP地址僅適用於本地網路
  • 如何使用Python自动化发送消息:用pynput库批量输入并发送文本
  • 【欢迎讨论方案一的可行性】SpringBoot集成netty,在handler中调用@Component注解的类
  • MLP、CNN、Transformer 的区别解析
  • gitlab 还原合并请求
  • Markdown如何导出Html文件Markdown文件
  • H3C无线产品案例汇编
  • RC充电电路仿真与分析
  • 关于 PPPOE技术的详细解释
  • LLaMA:开放和高效的基础语言模型集
  • 主流在售AI电子宠物产品
  • STM32裸机开发转FreeRTOS教程
  • Unity is running as administrator解决办法
  • Flink operator实现自动扩缩容
  • GAN对抗生成网络(一)——基本原理及数学推导
  • 结合长短期记忆网络(LSTM)和无迹卡尔曼滤波器(UKF)的技术在机器人导航和状态估计中的应用前景
  • 力扣-数据结构-9【算法学习day.80】
  • 30分钟搭建 Typecho 个人博客教程
  • 使用exe4j将jar转成exe、java打包exe
  • vue v-for 数据增加页面不刷新
  • EasyExcel自定义动态下拉框(附加业务对象转换功能)
  • chatglm3如何进行微调
  • 在pytest钩子函数中判断Android和iOS设备(方法二)
  • libmodbus主机通信主要函数分析
  • 2021年国家公考《申论》题(地市级)