随笔 - 303  文章 - 0  评论 - 3  阅读 - 15万

Spring Cloud之统一配置中心Config配置手工刷新

  实际上,配置文件也是随着应用场景变化的,如果服务已经启动并在使用过程中时需要修改其中某些配置,微服务可以直接识别并使用么?下面以Spring Cloud之统一配置中心Config初体验 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中案例继续实践配置手工刷新。

  修改配置productservice.properties中foo的值,如下:

        

   输入http://localhost:2200/config/foo并访问:

        

   访问结果还是未修改之前的值,说明修改后的值并未被微服务识别。那config server端识别了这个更改么?输入http://localhost:8888/productservice/default并访问:

        

  可见实际上仓库配置文件修改后,config server端获取了最新的配置信息但是config client却不是立即识别——因为client读取的是缓存信息。

  那client端一定要重启服务才能获取最新配置么?当然不是,只需要⼿动的做⼀些其他的操作(访问⼀个地址/refresh)刷新,之后再访问即可——客户端使
post去触发refresh,获取最新数据。操作如下:

  1Client客户端添加依赖spring-boot-starter-actuator

    对于spring-boot-starter-actuator在微服务健康监控之Spring Actuator初识 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中进行了简单的应用介绍,此处不再赘述。
  2Client客户端bootstrap.yml中添加配置(暴露通信端点)

        management.endpoints.web.exposure.include=refresh(也可以使用="*"暴露所有端口)

  3Client客户端使⽤到配置信息的类上添加@RefreshScope

        

  4)⼿动向Client客户端发起POST请求, http://localhost:2200/actuator/refresh,刷新配置信息。
        

         

 

 







  

 

posted on   池塘里洗澡的鸭子  阅读(189)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2021-12-08 Spring Cloud之微服务注册到Eureka Server集群后访问改造
2021-12-08 Spring Cloud之微服务注册到Eureka Server集群
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示