0


SpringCloud整合nacos配置中心bootstrap.yml多环境配置


前言

    我们在SpringCloud项目引入nacos作为配置中心后,为了方便开发,通常会有:local、test、prod等多个环境,本地调试代码用local的配置,测试环境打包用test的配置,生产环境打包用prod配置。本文以实际项目为例,给出了配置方法。并且基于生产环境,nacos账密需要定期修改,给出了生产环境配置bootstrap.yml配置文件的方案,仅供参考。

一、配置文件bootstrap.yml打在jar包里

1.项目pom.xml文件配置环境及nacos信息

<profiles>标签配置不同环境的信息如下:

<profiles>
        <!--本地环境-->
        <profile>
            <id>local</id>
            <properties>
                <activatedProperties>local</activatedProperties>
                <nacosConfigAddr>127.0.0.1:8848</nacosConfigAddr>
                <nacosNameSpace>d4460cce-jfh3-4a3e-92a8-51f597049999</nacosNameSpace>
                <nacosUserName>nacos</nacosUserName>
                <nacosPassword>123456</nacosPassword>
            </properties>
        </profile>

        <!--测试环境-->
        <profile>
            <id>base-test</id>
            <properties>
                <activatedProperties>test</activatedProperties>
                <nacosConfigAddr>127.0.0.2:8848</nacosConfigAddr>
                <nacosNameSpace>d4460cce-gd54-4a3e-92a8-51f597049998</nacosNameSpace>
                <logstashAddr>173.16.204.246:4567</logstashAddr>
                <nacosUserName>nacos</nacosUserName>
                <nacosPassword>123456</nacosPassword>
            </properties>
        </profile>

        <!--生产环境-->
        <profile>
            <id>jiguan-prod</id>
            <properties>
                <activatedProperties>prod</activatedProperties>
                <nacosConfigAddr>127.0.0.3:8848</nacosConfigAddr>
                <nacosNameSpace>d4460cce-yrhs-4a3e-92a8-51f597049997</nacosNameSpace>
                <nacosUserName>nacos</nacosUserName>
                <nacosPassword>123456</nacosPassword>
            </properties>
        </profile>
    </profiles>

<activatedProperties>标签配置环境名

<nacosConfigAddr>标签配置nacos服务的ip:端口

<nacosNameSpace>标签配置nacos命名空间

<nacosUserName>标签配置连接nacos服务的账号

<nacosPassword>标签配置连接nacos服务的密码

2.每个微服务模块下的bootstrap.yml配置文件配置如下:

业务模块配置:

spring:
  security:
    type: springboot
  profiles:
    active: @activatedProperties@
  cloud:
    nacos:
      config:
        # 共享配置的DataId,多个使用,分隔
        # 越靠后,优先级越高;
        # .yaml后缀不能少,只支持yaml/properties
        shared-dataids: common.yaml         #共享配置
        refreshable-dataids: common.yaml    #可刷新共享配置
        server-addr: @nacosConfigAddr@      #nacos server地址
        namespace: @nacosNameSpace@         #命名空间,代指某个环境
        file-extension: yaml                #dataId扩展名
        username: @nacosUserName@
        password: @nacosPassword@  
  application:
    name: test-center  #服务名称

api-gateway网关模块配置:

spring:
  security:
    type: gateway
  profiles:
    active: @activatedProperties@
  cloud:
    nacos:
      config:
        # 共享配置的DataId,多个使用,分隔
        # 越靠后,优先级越高;
        # .yaml后缀不能少,只支持yaml/properties
        shared-dataids: common.yaml         #共享配置
        refreshable-dataids: common.yaml    #可刷新共享配置
        server-addr: @nacosConfigAddr@      #nacos server地址
        file-extension: yaml                #dataId扩展名
        namespace: @nacosNameSpace@         #命名空间 代指某个环境
        username: @nacosUserName@
        password: @nacosPassword@
    sentinel:
      transport:
        # 指定sentinel 控制台的地址
        dashboard: 127.0.0.1:8080
      eager: true
  application:
    name: api-gateway
  main:
    allow-bean-definition-overriding: true
    user:
      name: admin
      password: admin@123
      roles: admin
#metrics
management:
  endpoints:
    web:
      exposure:
        include: "*"
  endpoint:
    gateway:
      enabled: false
    chaosmonkey:
      enabled: true
    health:
      show-details: always

项目启动或者打包时,idea工具勾选对应的环境,项目就会动态获取对应环境的nacos配置,去连接nacos配置中心了。这种方式是把nacos账密信息打在程序包里,项目启动时读取程序里的配置信息连接nacos服务获取项目的业务配置信息。

    这种方式有个弊端就是,在生产环境,当我们需要定期修改nacos配置信息以保障项目安全时,每次修改nacos服务的密码,都需要重新打包部署项目服务。要想在修改了nacos密码后不需要重新打包就能更新nacos密码,就需要将bootstrap.yml配置放到服务器上,这样修改完nacos配置信息,只需要在服务器上重启服务就好了。

二、配置文件bootstrap.yml放在服务器上

1.服务器微服务jar包同级目录创建config文件夹

mkdir config;

将bootstrap.yml配置文件放到config目录下,把启动环境信息还有nacos账密信息放到yml文件中,其余每个项目特有的信息(如:应用名称,security类型)放到项目代码中的bootstrap.yml配置文件中。

2.服务器上bootstrap.yml配置文件

spring:
  profiles:
    active: prod
  cloud:
    nacos:
      config:
        # 共享配置的DataId,多个使用,分隔
        # 越靠后,优先级越高;
        # .yaml后缀不能少,只支持yaml/properties
        shared-dataids: common.yaml                      #共享配置
        refreshable-dataids: common.yaml                 #可刷新共享配置
        server-addr: 127.0.0.3:4848                      #nacos server地址
        namespace: d4460cce-yrhs-4a3e-92a8-51f597049997  #命名空间代指某个环境
        file-extension: yaml                             #dataId扩展名
        username: nacos
        password: ENC(qDYb89YM4BP9gRFvjqTTqZGeQ==)

#jasypt加密
jasypt:
  encryptor:
    password: 1115@11

3.代码中resource目录下bootstrap.yml配置文件

业务模块的配置:

spring:
  security:
    type: springboot  
  application:
    name: test-center

api-gateway网关模块配置:

spring:
  security:
    type: gateway
    sentinel:
      transport:
        # 指定sentinel 控制台的地址
        dashboard: 127.0.0.1:8080
      eager: true
  application:
    name: api-gateway
  main:
    allow-bean-definition-overriding: true
    user:
      name: admin
      password: admin@123
      roles: admin

总结

    springCloud项目启动时会先读取项目jar包同级目录下config目录中的yml配置,然后才会去项目jar包中读取resource目录下的yml配置,我们把各微服务模块共用的nacos账密信息和启动环境等配置放到服务器上,把各模块个性化配置放到服务jar包中,这样就能很好的处理nacos账密定期更新的问题,降低nacos密码更新对项目变更的影响。

本文转载自: https://blog.csdn.net/weixin_42925623/article/details/134496940
版权归原作者 通道已损坏 所有, 如有侵权,请联系我们删除。

“SpringCloud整合nacos配置中心bootstrap.yml多环境配置”的评论:

还没有评论