文章目录
简介
前边写过几个微服务,订单微服务,商品微服务,账户微服务,库存微服务,每个微服务都去配置自己的配置文件,每个微服务一个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);
}
}
改配置
这里就不进行讲解所有微服务的配置了。