需要解决的问题
1.实现配置更改热更新,而不是改动了配置文件还要去重启服务才能生效。
2.对多个微服务的配置文件统一集中管理。而不是需要对每个微服务逐一去修改配置文件,特别是公共通用的配置。
配置管理服务中的配置发生改变后,回去立马通知各个微服务完成对最新配置的读取,并完成热更新。
Nacos管理控制台的配置管理
配置文件的Data ID:服务名称-profile.后缀名
微服务如何读取到nacos中的配置信息
bootstrap.yml引导文件的优先级 > application.yml
优先级:application.properties > application.yml > application.yaml
引入nacos配置管理的pom坐标依赖:
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>
bootstrap.yml文件的内容:
spring:application:name: order-service # 服务名称profiles:active: dev # 开发环境cloud:nacos:server-addr: localhost:8848 # Nacos地址config:file-extension: yaml # 文件后缀名
正好对应了nacos管理控制台中配置文件的名称: order-service-dev.yaml
application.yml中与bootstrap.yml配置中重复的配置给注释掉。
server:port: 8080
spring:datasource:url: jdbc:mysql://localhost:3306/cloud_order?useSSL=falseusername: rootpassword: 123456driver-class-name: com.mysql.jdbc.Driver
# application:
# name: order-servicecloud:nacos:
# server-addr: localhost:8848 #nacos服务端地址discovery:cluster-name: chengdu #配置集群名称也就是机房位置
# namespace: 713c0b99-4de3-4774-b186-b9b3a94f60d0 #配置命名空间的id
mybatis:type-aliases-package: com.xkj.org.pojoconfiguration:map-underscore-to-camel-case: truelogging:level:com.xkj.org: debugpattern:dateformat: MM-dd HH:mm:ss:SSS
#eureka:
# client:
# service-url:
# defaultZone: http://localhost:10086/eureka/user-service:ribbon:
# NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule #负载均衡规则NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule #负载均衡规则
ribbon:eager-load:enabled: true # 开启饥饿加载clients:- user-service #对user-service这个服务饥饿加载
@Value("${pattern.dateformat}")private String dateformat;@GetMapping("now")public String now() {log.info("dateformat={}", dateformat);return LocalDateTime.now().format(DateTimeFormatter.ofPattern(dateformat, Locale.CHINA));}