Springcloud中的Nacos Config服务配置流程分析
作者:java爱好者牛奶糖
简介
前边写过几个微服务,订单微服务,商品微服务,账户微服务,库存微服务,每个微服务都去配置自己的配置文件,每个微服务一个yml配置文件,这样如果微服务足够多,对于配置文件的管理就很麻烦,如果配置文件变动需要更改,则需要我们一个一个的去改。例如开发环境,测试环境,生产环境等等,而且配置文件无法实时更新。我们修改了配置文件之后,必须重新启动微服务才能使配置生效。配置中心就可以解决配置问题。
配置中心流程:
首先把项目中各种配置全部都放到一个集中的地方进行统一管理,并提供一套标准的接口。
当各个服务需要获取配置的时候,就来配置中心的接口拉取自己的配置。
当配置中心中的各种参数有更新的时候,也能通知到各个服务实时的过来同步最新的信息,使之动态更新。
nacos config快速开始
以用户微服务为例,进行统一的配置。
依赖引入
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>2.1.0.RELEASE</version> </dependency>
配置nacos config
现在需要将原来的application.yml配置在nacos的服务配置 管理中进行,而原本微服务需要新建一个bootstrap.yml作为配置文件。配置文件的优先级:bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml
spring: application: name: springcloud-user cloud: nacos: config: server-addr: 192.168.5.130:8848 #nacos中心地址i file-extension: yaml # 配置文件格式 profiles: active: dev # 环境标识
nacos服务中心配置
新建配置
注意:dataid配置需要application.name+dev.yaml
对应的数据库表:
启动测试
注释本地的application.yam中的内容, 启动程序进行测试
如果依旧可以成功访问程序,说明我们nacos的配置中心功能已经实现
配置动态更新配置
配置中心配置动态的属性,在代码里边进行获取。
config: appName: user
代码里边获取:
@RestController @RefreshScope /* 只需要在需要动态读取配置的类上添加此注解就可以 */ public class NacosConfigController { @Value( "${config.appName}" ) private String appName; /* 2 注解方式 */ @GetMapping( "/nacos-config" ) public String nacosConfing() { return(appName); } }
改配置
这里就不进行讲解所有微服务的配置了。
到此这篇关于Springcloud中的Nacos Config服务配置的文章就介绍到这了,更多相关Springcloud Nacos服务配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!