不管学习什么技术,官网永远是第一选择。
官网: https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html
Nacos服务配置比之前服务多了一个spring-cloud-starter-alibaba-nacos-config依赖
pom.xml
4.0.0 com.jiny MySpringCloudAlibaba 0.0.1-SNAPSHOT com.jiny cloudalibaba-config-3377 0.0.1-SNAPSHOT cloudalibaba-config-3377 Demo project for Spring Boot 1.8 com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery com.alibaba.cloud spring-cloud-starter-alibaba-nacos-config org.springframework.boot spring-boot-starter org.springframework.boot spring-boot-starter-test test
要注意的是这里我们要配置两个,因为Nacos同SpringCloud-config一样,在项目初始化时,要保证先从配置中心进行配置拉取,拉取配置之后,才能保证项目的正常启动。springboot中配置文件的加载是存在优先级顺序的,bootstrap优先级高于application分别要配置的是,这里bootstrap.yml配置好了以后,作用是两个,第一个让3377这个服务注册到Nacos中,第二个作用就是去Nacos中去读取指定后缀为yaml的配置文件:
bootstrap.yml
4.0.0 com.jiny MySpringCloudAlibaba 0.0.1-SNAPSHOT com.jiny cloudalibaba-config-3377 0.0.1-SNAPSHOT cloudalibaba-config-3377 Demo project for Spring Boot 1.8 com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery com.alibaba.cloud spring-cloud-starter-alibaba-nacos-config org.springframework.boot spring-boot-starter org.springframework.boot spring-boot-starter-test test
application.yml
4.0.0 com.jiny MySpringCloudAlibaba 0.0.1-SNAPSHOT com.jiny cloudalibaba-config-3377 0.0.1-SNAPSHOT cloudalibaba-config-3377 Demo project for Spring Boot 1.8 com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery com.alibaba.cloud spring-cloud-starter-alibaba-nacos-config org.springframework.boot spring-boot-starter org.springframework.boot spring-boot-starter-test test
启动类添加@EnableDiscoveryClient
@SpringBootApplication
@EnableDiscoveryClient
public class CloudalibabaConfig3377Application {
public static void main(String[] args) {
SpringApplication.run(CloudalibabaConfig3377Application.class, args);
}
}
业务类
这里的@RefreshScope实现配置自动更新,意思为如果想要使配置文件中的配置修改后不用重启项目即生效,可以使用@RefreshScope配置来实现
@RestController
@RefreshScope //支持Nacos的动态刷新功能
public class ConfigClientController {
@Value("${config.info}")
private String configInfo;
// @Value("${/config/info}")
@RequestMapping("/config/info")
public String getConfigInfo(){
return configInfo;
}
}
使用Nacos作为配置中心
Nacos配置规则
在 Nacos Spring Cloud 中,dataId 的完整格式如下(详情可以参考官网 https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html):
${prefix}-${spring.profiles.active}.${file-extension}
1. `prefix` 默认为 `spring.application.name` 的值,也可以通过配置项 `spring.cloud.nacos.config.prefix`来配置。
2. `spring.profiles.active` 即为当前环境对应的 profile,注意:**当 `spring.profiles.active` 为空时,对应的连接符 `-` 也将不存在,dataId 的拼接格式变成 `${prefix}.${file-extension}`**(不能删除)
3. `file-exetension` 为配置内容的数据格式,可以通过配置项 `spring.cloud.nacos.config.file-extension` 来配置。目前只支持 `properties` 和 `yaml` 类型。
4. 通过 Spring Cloud 原生注解 `@RefreshScope` 实现配置自动更新:
5. 所以根据官方给出的规则我们最终需要在Nacos配置中心添加的配置文件的名字规则和名字为:
6. # ${spring.application.name}-${spring.profiles.active}.${file-extension}
# nacos-config-client-dev.yaml
# 微服务名称-当前环境-文件格式
下图为创建的一个配置
启动项目,访问
http://localhost:3377/config/info
修改配置文件,访问,可以看到访问数据在服务不需要重启的情况下已经更新。



