spring boot 2.6.x接入spring cloud alibaba 2021.x版本nacos

简介: spring cloud alibaba 2021.x版本nacos配置中心对接spring boot 2.6版本。

我的 spring boot 2.6.x版本与spring cloud alibaba 2021.x版本的nacos对接的过程。

首先pom加入引用(这里同时加入了注册中心和配置中心):

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


项目启动类上添加 @EnableDiscoveryClient注解:

@SpringBootApplication@Slf4j@EnableDiscoveryClient@RefreshScopepublicclassStructureApplication {
publicstaticvoidmain(String[] args) {
SpringApplication.run(StructureApplication.class, args);
log.info("StructureApplication started successfully");
    }
}


添加application.yml文件:

server:  port: 8081  servlet:    context-path: /sp-structure
spring:  application:    name: sp-structure-application
  profiles:    active: dev

在application.yml中指定了激活dev环境配置。因此项目中添加application-dev.yml:


spring:  cloud:    nacos:      config:        group: DEFAULT_GROUP
        server-addr: localhost:8848        namespace: c2897240-442e-4e0e-be5a-eef34d65341d
  config:    import:      - optional:nacos:sp-structure-application-dev.yml

上述配置中的group和namespace是nacos中配置的group和namespace。登录nacos,在group DEFAULT_GROUP和namespace c2897240-442e-4e0e-be5a-eef34d65341d中添加一个名为sp-structure-application-dev.yml的配置文件


微信截图_20221118191817.png

配置文件中配置了注册中心、数据库等配置:

spring:  datasource:    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/simple?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=Asia/Shanghai&rewriteBatchedStatements=true
    username: root
    password: root
    type: com.alibaba.druid.pool.DruidDataSource
    druid:# 初始化时建立物理连接的个数      initialSize: 5# 最小连接池数量      minIdle: 5# 最大连接池数量      maxActive: 201# 获取连接时最大等待时间,单位毫秒      maxWait: 60000# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒      timeBetweenEvictionRunsMillis: 60000# 连接保持空闲而不被驱逐的最小时间      minEvictableIdleTimeMillis: 300000# 用来测试连接是否可用的SQL语句,默认值每种数据库都不相同,这是mysql      validationQuery: select 1
# 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。      testWhileIdle: true  cloud:    nacos:      discovery:        server-addr: localhost:8848        group: DEFAULT_GROUP
        namespace: c2897240-442e-4e0e-be5a-eef34d65341d


启动项目,成功注册到nacos注册中心,成功拉取到配置。


下面再尝试一个场景:假如一个项目有很多配置信息,如果放在一个yml文件中可能比较庞大。也许可以将配置分类放在多个yml中进行管理。下面尝试在这个项目中添加一个自定义的string配置。

首先增加一点Controller代码:

@RestController@RefreshScopepublicclassSimController {
@Value("${conf.nac.str.examp:}")
privateStringnacosExamp;
@PostMapping("/strConf")
@SentinelResource(value="/strConf")
publicStringgetStrConfig() {
returnnacosExamp;
    }
}


计划将conf.nac.str.examp这个配置独立另放一个配置文件。

所以,修改application-dev.yml的配置,增加一个配置文件:

spring:  cloud:    nacos:      config:        group: DEFAULT_GROUP
        server-addr: localhost:8848        namespace: c2897240-442e-4e0e-be5a-eef34d65341d
  config:    import:      - optional:nacos:sp-structure-application-dev.yml
      - optional:nacos:${spring.application.name}-tyy-${spring.profiles.active}.yml

上面新的配置文件的名称换了一种写法。使用${}占位符替代名称。系统会使用环境变量替代,最终就是sp-structure-application-tyy-dev.yml

修改以上配置后,重启服务。

之后在nacos中添加一个新的名为sp-structure-application-tyy-dev.yml的配置文件(注意group和namespace),里面添加一个配置:

conf:  nac:    str:      examp: hello world

nacos发布后,访问controller的接口,可以正确返回 hello world。

相关文章
|
6月前
|
人工智能 Java Nacos
基于 Spring AI Alibaba + Nacos 的分布式 Multi-Agent 构建指南
本文将针对 Spring AI Alibaba + Nacos 的分布式多智能体构建方案展开介绍,同时结合 Demo 说明快速开发方法与实际效果。
4817 92
|
6月前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
7309 98
|
7月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
6445 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
|
6月前
|
人工智能 监控 Java
Spring AI Alibaba实践|后台定时Agent
基于Spring AI Alibaba框架,可构建自主运行的AI Agent,突破传统Chat模式限制,支持定时任务、事件响应与人工协同,实现数据采集、分析到决策的自动化闭环,提升企业智能化效率。
Spring AI Alibaba实践|后台定时Agent
|
SpringCloudAlibaba API 开发者
新版-SpringCloud+SpringCloud Alibaba
新版-SpringCloud+SpringCloud Alibaba
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
定时任务在企业应用中至关重要,常用于异步数据处理、自动化运维等场景。在单体应用中,利用Java的`java.util.Timer`或Spring的`@Scheduled`即可轻松实现。然而,进入微服务架构后,任务可能因多节点并发执行而重复。Spring Cloud Alibaba为此发布了Scheduling模块,提供轻量级、高可用的分布式定时任务解决方案,支持防重复执行、分片运行等功能,并可通过`spring-cloud-starter-alibaba-schedulerx`快速集成。用户可选择基于阿里云SchedulerX托管服务或采用本地开源方案(如ShedLock)
539 1
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
人工智能 SpringCloudAlibaba 自然语言处理
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
5075 2
|
Java Nacos Sentinel
Spring Cloud Alibaba:一站式微服务解决方案
Spring Cloud Alibaba(简称SCA) 是一个基于 Spring Cloud 构建的开源微服务框架,专为解决分布式系统中的服务治理、配置管理、服务发现、消息总线等问题而设计。
3062 13
Spring Cloud Alibaba:一站式微服务解决方案
|
SpringCloudAlibaba 负载均衡 Dubbo
【SpringCloud Alibaba系列】Dubbo高级特性篇
本章我们介绍Dubbo的常用高级特性,包括序列化、地址缓存、超时与重试机制、多版本、负载均衡。集群容错、服务降级等。
2025 7
【SpringCloud Alibaba系列】Dubbo高级特性篇