简介
前边写过几个微服务,订单微服务,商品微服务,账户微服务,库存微服务,每个微服务都去配置自己的配置文件,每个微服务一个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
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;
@GetMapping( "/nacos-config" )
public String nacosConfing()
{
return(appName);
}
}
改配置 这里就不进行讲解所有微服务的配置了。
|