【已解决】Nacos作为配置中心的时候,使用@Value注解一直提示Could not resolve placeholder

  • 作者: 凯哥Java(公众号:凯哥Java)
  • Nacos
  • 时间:2022-10-23 13:00
  • 5226人已阅读
简介 在使用Nacos作为统一配置中心的时候,项目中使用@Value注解从Nacos获取值,一直报错 为什么你的项目中使用Nacos获取值一直报错?

🔔🔔🔔好消息!好消息!🔔🔔🔔

有需要的朋友👉:联系凯哥 微信号 kaigejava2022

在使用Nacos作为统一配置中心的时候,项目中使用@Value注解从Nacos获取值,一直报错Could not resolve placeholder 'blog.website' in value "${blog.website}".如下图:

9f3568be11320f0bce2756fbad928a37.png

问题分析:难道是@Value的${}中key写错了?

来看看Nacos的配置

13dee4dced8fa921a0132d77d6eafe1c.png

没有写错啊

难道bootstrap.yml中Nacos的dataId写错了?查看bootstrap.yml

b45f06657fd757fe4f4eb517ae8811d1.png

也没有写错啊。

那还有哪了问题呢?

其实啊,主要是因为我们忘记了,Nacos还有一个namespace来作为数据隔离的

凯哥的问题就出在了namespace上。

我们回到Nacos控制台,来看看配置列表.如下图:

3c4d0d9b65f19da797eb983757dc2d46.png

是不是发现了什么?对,没错!userservice-dev.yaml的namespace是在spe下,而不是public下(在bootstrap.yml文件中,我们没有指定namespace,那么默认就是在public的namespace下)。所以,项目启动时候,默认去public的命名空间下获取blog.website。

e7cd070d487aab3155961356bbd0bbd8.png

我们看到public的namesp下没有数据。当然会报错了。

修改:

将配置信息写到public的namespace下

7c97dadf8106ffdb341bda6377726457.png

重新启动项目,查看控制台日志。一切正常。

访问项目:

8c76d031fc79f6b6f2ddbe266c751198.png

可以正常且正确的返回数据。

总结:

Spring boot和Nacos整合,使用Nacos作为统一配置中心的时候,当@Value不识别错误检查以下三个地方:

1:查看@Vaule${}中的key值是否是争取的。

需要注意:在yml中blog:website。但是在@Value中是blog.website

2:查看bootstrap.yml的dataId和Nacos配置中的名字是否一致:

b45f06657fd757fe4f4eb517ae8811d1.png

3:检查namespace是否在同一个

如果没有写,Nacos的默认namespace是在public下。

注意看是否有多个命名空间,每个命名空间是独立的,叫做环境隔离,不同的命名空间下的服务互相不可见。我不小心把nacos的yml创建在了dev的命名空间下,而我的服务默认是在public下,两者之间没有关联,所以报错了,改过来就解决了!


TopTop