spring boot项目中使用nacos作为配置中心

Posted 左直拳

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring boot项目中使用nacos作为配置中心相关的知识,希望对你有一定的参考价值。

利用nacos作为配置中心,好处不言而喻,配置外置了,与程序解耦,并且nacos还提供了友好的管理界面。spring boot的卖点之一,就是与之前的spring相比,所谓约定重于配置,配置文件大大简化。现在使用nacos这种外置配置中心,是更加向前了一步。

具体应用步骤:

1、pom.xml中引入nacos支持包
2、pom.xml中指向nacos
3、配置文件中使用nacos配置项

如此,即可使用nacos中的配置,修改啥的都很方便,根本不用远程服务器。如果设置refresh选项,连程序都不用重启,即时刷新。下面是详细介绍:

1、pom.xml中引入nacos支持包

<!--阿里巴巴 nacos 服务发现(这个可以去掉?)-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--阿里巴巴 nacos 配置中心-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

2、pom.xml中指向nacos

这里其实还没有指向nacos,只是定义了一些属性。因为我们这个项目准确来说,是个spring cloud项目(spring cloud居于spring boot),里面包含多个子系统,因此在最外层的pom.xml定义了公共属性,其中包含nacos。如果只是spring boot,那么可以省去这一步。

<profile>
	。。。
    <properties>
。。。
        <!--Nacos配置中心地址-->
        <config.server-addr>192.168.10.248:8848</config.server-addr>
        <!--Nacos配置中心命名空间,用于支持多环境.这里必须使用ID,不能使用名称,默认为空-->
        <config.namespace>gdhysthj</config.namespace>
        <!--nacos用户名-->
        <config.username>nacos</config.username>
        <!--nacos密码-->
        <config.password>nacos</config.password>
。。。
    </properties>
</profile>

3、配置文件中使用nacos配置项

由于我这个spring boot项目使用了spring cloud,它有一个bootstrap.yml(bootstrap,绑鞋带?引申为步步为营、引导程序之意),对nacos的应用即在于此。我猜spring boot项目,直接在application.properties中定义也可以的。

spring:
	。。。
    cloud:
		。。。
        nacos:
            config:
                namespace: $config.namespace #这些就是前面定义的公共属性。如果是spring boot,直接写值应该也可以
                server-addr: $config.server-addr
                username: $config.username
                password: $config.password
                shared-configs[0]:
                  data-id: common.properties
                  refresh: true #自动刷新
                shared-configs[1]:
                  data-id: db_oracle.properties
                  group: YJZH_GROUP
                  refresh: true
                shared-configs[2]:
                  data-id: redis.properties
                  refresh: true
                shared-configs[3]:
                  data-id: rabbitmq.properties
                  refresh: true
                shared-configs[4]:
                  data-id: minio.properties
                  refresh: true
            discovery:
              namespace: $config.namespace
              server-addr: $discovery.server-addr
              username: $config.username
              password: $config.password

		。。。


由上图可知,指定的命名空间下,有好几个配置文件,然后它们以数组的形式,在spring cloud的bootstrap.yml文件中被指定:shared-configs[0]、shared-configs[1]、。。。其实将这些分散的配置文件的内容写在一起,合成一个文件也是可以的。不管是一个文件或多个文件,对于系统来说,最终都是一个配置的集合。shared-configs[x]是nacos推荐的写法,原先是ext-config[x],现在已经弃用了。配置文件的书写顺序不重要,一个配置文件,比如db.properties,你放在shared-configs[0]或者shared-configs[1]都没关系。

 shared-configs[1]:
   data-id: db_oracle.properties
   group: YJZH_GROUP #如果同一个命名空间下,配置文件名称相同咋办?用不同分组名称
   refresh: true #是否自动刷新。true的hua,更改nacos配置,在应用这里会立即生效

小结

nacos中的配置,和我们平时写在application.propertis/application.yml中的配置并无不同,在系统中是同样使用。

以上是关于spring boot项目中使用nacos作为配置中心的主要内容,如果未能解决你的问题,请参考以下文章

spring boot使用nacos作为配置中心实践

Spring boot集成Nacos-配置中心详解

SpringBoot与Nacos整合

spring boot 使用 k8s 的 configMap 作为外部配置

spring boot中@ConfigurationProperties的使用

基于Spring Boot的程序的配置读取方案