springcloud nacos config快速入门

nacos config

1.为什么需要配置中心?

传统配置的方式已经暴露出了很多问题,其他的诸如:历史版本管理,权限控制,安全性等等问题,是传统的配置文件无法解决的!

随着业务的发展、微服务架构的升级,服务的数量、程序的配置日益增多(各种微服务、各种服务器地址、各种参数),传统的配置文件方式和数据库的方式已无法满足开发人员对配置管理的要求:

安全性:配置跟随源代码保存在代码库中,容易造成配置泄漏;
时效性:修改配置,需要重启服务才能生效;
局限性:无法支持动态调整:例如日志开关、功能开关;
因此,我们需要配置中心来统一管理配置!把业务开发者从复杂以及繁琐的配置中解脱出来,只需专注于业务代码本身,从而能够显著提升开发以及运维效率。同时将配置和发布包解藕也进一步提升发布的成功率,并为运维的细力度管控、应急处理等提供强有力的支持。

2.使用nacos config配置中心

1.添加依赖:

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<!-- 如果是使用springcloud2020后的版本还需引入以下用来加载bootstrap文件 -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>

2.在运行此 Example 之前, 必须使用 bootstrap.properties 配置文件来配置Nacos Server 地址(优先加载bootstrap配置)

bootstrap.properties

spring.application.name=example
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
#spring.cloud.nacos.config.file-extension=yaml 如果想使用yaml 文件配置
#spring.cloud.nacos.config.enabled = false  完全关闭配置
Note 注意当你使用域名的方式来访问 Nacos 时,spring.cloud.nacos.config.server-addr 配置的方式为 域名:port。 例如 Nacos 的域名为abc.com.nacos,监听的端口为 80,则 spring.cloud.nacos.config.server-addr=abc.com.nacos:80。 注意 80 端口不能省略。

在 Nacos Spring Cloud 中,dataId 的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。

  • spring.profiles.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档注意:当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}

  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 propertiesyaml 类型。

  • Note ${spring.profiles.active} 当通过配置文件来指定时必须放在 bootstrap.properties 文件中。

3.创建服务配置,dataid为example.properties(因为没有设置spring.profiles.active所以名称为spring.application.name),并写入useLocalCache=flase

springcloud nacos config快速入门

4.新建ConfigController.java 用来测试是否配置成功,@RefreshScop为动态刷新配置

@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {

    @Value("${useLocalCache:true}")
    private boolean useLocalCache;

    @RequestMapping("/get")
    public boolean get() {
        return useLocalCache;
    }
}

3.测试

1.访问

http://localhost:8080/config/get

返回结果为flase

2.修改example.propertiesuseLocalCache=flase为true

再次访问

http://localhost:8080/config/get

返回结果为true

完成对配置文件的动态刷新。

上一篇:JMeter——JMeter如何进行汉化


下一篇:SpringBoot自动配置原理