SpringCloudAlibaba微服务启动报错

控制台日志打印异常信息

java 复制代码
17:14:12.648 [main] DEBUG org.springframework.boot.diagnostics.LoggingFailureAnalysisReporter - Application failed to start due to an exception
org.springframework.cloud.commons.ConfigDataMissingEnvironmentPostProcessor$ImportException: No spring.config.import set
        at org.springframework.cloud.commons.ConfigDataMissingEnvironmentPostProcessor.postProcessEnvironment(ConfigDataMissingEnvironmentPostProcessor.java:82)
        at org.springframework.boot.env.EnvironmentPostProcessorApplicationListener.onApplicationEnvironmentPreparedEvent(EnvironmentPostProcessorApplicationListener.java:102)
        at org.springframework.boot.env.EnvironmentPostProcessorApplicationListener.onApplicationEvent(EnvironmentPostProcessorApplicationListener.java:87)
        at org.springframework.context.event.SimpleApplicationEventMulticaster.doInvokeListener(SimpleApplicationEventMulticaster.java:178)
        at org.springframework.context.event.SimpleApplicationEventMulticaster.invokeListener(SimpleApplicationEventMulticaster.java:171)
        at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:145)
        at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:133)
        at org.springframework.boot.context.event.EventPublishingRunListener.environmentPrepared(EventPublishingRunListener.java:85)
        at org.springframework.boot.SpringApplicationRunListeners.lambda$environmentPrepared$2(SpringApplicationRunListeners.java:66)
        at java.base/java.util.ArrayList.forEach(ArrayList.java:1541)
        at org.springframework.boot.SpringApplicationRunListeners.doWithListeners(SpringApplicationRunListeners.java:120)
        at org.springframework.boot.SpringApplicationRunListeners.doWithListeners(SpringApplicationRunListeners.java:114)
        at org.springframework.boot.SpringApplicationRunListeners.environmentPrepared(SpringApplicationRunListeners.java:65)
        at org.springframework.boot.SpringApplication.prepareEnvironment(SpringApplication.java:344)
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:302)
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:1300)
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:1289)
        at com.mall.user.UserApplication.main(UserApplication.java:15)
17:14:12.651 [main] ERROR org.springframework.boot.diagnostics.LoggingFailureAnalysisReporter - 

***************************
APPLICATION FAILED TO START
***************************

Description:

No spring.config.import property has been defined

Action:

Add a spring.config.import=nacos: property to your configuration.
        If configuration is not required add spring.config.import=optional:nacos: instead.
        To disable this check, set spring.cloud.nacos.config.import-check.enabled=false.

配置文件

以上是一个服务启动时的日志,无法启动。配置文件中没配置spring.cloud.nacos.config,为什么仍然提示配置spring.config.import?

原因及解决方案

问题很清楚。mall-user/pom.xml 中依赖了 spring-cloud-starter-alibaba-nacos-config,Spring Cloud Alibaba 2021.0.5.0 会强制校验 spring.config.import 是否配置------跟 application.yml 里有没有 spring.cloud.nacos.config 块无关。

你有三种修复方式,选一种即可:


方案一:禁用强制检查(最简单)

复制代码
spring:
  cloud:
    nacos:
      config:
        import-check:
          enabled: false

适用场景:只需要 discovery,不需要 config 中心。


方案二:补上 spring.config.import

复制代码
spring:
  config:
    import:
      - optional:nacos:mall-user.yaml?refreshEnabled=true

适用场景:确实需要从 Nacos 加载配置。但要注意 Nacos 上 mall-user.yaml 的编码问题(之前报 MalformedInputException 就是因为 Nacos 上的文件编码不是合法 UTF-8)。


方案三:从 pom.xml 移除 config 依赖(最彻底)

mall-user/pom.xml 中的这一行删掉:

复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

适用场景:完全不需要 Nacos 配置中心,只用 discovery。


建议:先用方案一快速恢复启动,后续如果要用配置中心再切到方案二并修复 Nacos 上的文件编码。

相关推荐
无心水5 小时前
【分布式利器:SOAF】蚂蚁开源的金融级微服务全家桶:SOFAStack 核心架构与实战选型对比
人工智能·分布式·微服务·金融·架构·开源·分布式利器
深蓝电商API5 小时前
分布式电商爬虫架构:Scrapy-Redis+消息队列的集群部署
分布式·爬虫·架构
珂玥c5 小时前
k8s集群网络层碎碎念
云原生·容器·kubernetes
万里侯5 小时前
云原生安全扫描:保护容器化应用的安全
微服务·容器·k8s
小挪号底迪滴5 小时前
研发出海实战:全球化系统的时区陷阱、I18n架构与跨国协作避坑指南
架构
亚空间仓鼠5 小时前
Docker容器化高可用架构部署方案(十一)
android·docker·架构
ze^05 小时前
Day03 Web应用&OSS存储&负载均衡&CDN加速&反向代理&WAF防护&部署影响
web安全·网络安全·架构·安全架构
狼爷14 小时前
日均100万订单!「订单超时自动取消」全方案解析(附并发避坑指南)
架构
万里侯16 小时前
GitOps实战:用Git管理基础设施
微服务·容器·k8s