当前位置: 首页 > 编程笔记 >

SpringCloud Bus如何实现配置刷新

齐浩淼
2023-03-14
本文向大家介绍SpringCloud Bus如何实现配置刷新,包括了SpringCloud Bus如何实现配置刷新的使用技巧和注意事项,需要的朋友参考一下

要想实现配置刷新,首先得有项目基础结构

  • 项目一: 注册中心
  • 项目二: 配置中心
  • 项目三: 客户端

先启动注册中心

然后启动配置中心

然后在不同端口启动客户端的多个实例,这些实例都是通过bootstrap.properties连接到配置中心后,加载相应配置后启动的.

成功完成上述基础设施,才开始关注配置刷新.

==========================================================================================

SpringCloud Bus实现配置刷新只需要做以下几点:

1. 在配置中心和客户端都添加依赖: spring-cloud-starter-bus-amqp

说明: bus表示引入的是SpringCloud Bus的依赖, amqp表示bus的消息传递功能是通过rabbitmq实现.(如果想通过kafka实现,则对应的依赖是spring-cloud-starter-bus-kafka)

2. 在配置中心和客户端都添加连接消息中间件的配置,由于amqp用的是rabbitmq消息中间件,因此对应的配置是:

spring.rabbitmq.host=localhost
spring.rabbitmq.password=wwx614831
spring.rabbitmq.username=wwx614831
spring.rabbitmq.port=5672

3. 在配置中心的配置中加入不进行权限检查的配置:

management.security.enabled=false
4. 使用:

  通过获取配置文件中一个示例属性值,来判断配置是否真的刷新

  刷新前: 获取name属性值=wangxuejian

  更改为: name=xuejian

  刷新: 调用配置中心的bus/refresh接口

  看效果: 获取name属性值变成xuejian,且多个实例都改变了.

5. 注意:

  把需要刷新配置的Bean上标注@RefreshScope注解.

总结:

1. 首先搭建基础架构,实现配置中心和注册中心的正常使用

2. 使用什么消息中间件,就引入什么中间件的依赖

3. 跳过安全检查,避免401问题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍spring boot 配置动态刷新实现详解,包括了spring boot 配置动态刷新实现详解的使用技巧和注意事项,需要的朋友参考一下 本文测试使用的spring cloud版本为: Dalston.SR1 很多朋友只知道spring cloud config可以刷新远程git的配置到内存中, 却不知道spring cloud config的客户端可以脱离服务端使用, 更不知道sp

  • 400-错误请求-{“error”:“invalid_grant”,“error_description”:“Bad Request”} 我的请求URL如下所示: 当用户与代码一起被重定向回来时,我的令牌请求函数被调用: 返回Access&refresh令牌,并将其存储在数据库中,然后在我的refresh函数中使用,此处的令牌URI为https://www.googleapis.com/oauth

  • nginx安装好之后一般会在/etc/nginx/目录下有nginx.conf文件和conf.d目录,这其实已经帮我们预留了虚拟主机要准备的内容。 看下nginx.conf文件,里面有这样一行: include /etc/nginx/conf.d/*.conf; 那么也就是说ngixn启动都会自动加载conf.d目录下以.conf结尾的所有配置文件 ok,我们直接干掉nginx.conf里面se

  • 在nvue页面如何实现下拉刷新? 尝试用了uni-scroll-view这个组件发现没有效果

  • 问题内容: 我正在使用Spring 3.1.1.RELEASE,Hibernate 4.1.0.Final和JPA 2.0。有没有一种方法可以配置Spring事务以在不使用Java代码的情况下执行事务后提交?换句话说,我想将刷新模式设置为在应用程序上下文文件,hibernate配置文件或persistence.xml文件中提交。我的Spring交易服务类看起来像 我的应用程序上下文设置如下: 我的

  • 我已经在jboss eap中为特定用户配置了Kerberos身份验证,它运行良好。但希望根据组进行配置,即特定组中的用户将能够进行身份验证。 独立。用户的xml配置:- 我的环境包括: Linux服务器与JBoss EAP 6.2客户端站与Windows 7 64bitChromeWindows Server 2008 Active Directory(作为KDC) 应用战争地点:-https:/