总结
对于面试还是要好好准备的,尤其是有些问题还是很容易挖坑的,例如你为什么离开现在的公司(你当然不应该抱怨现在的公司有哪些不好的地方,更多的应该表明自己想要寻找更好的发展机会,自己的一些现实因素,比如对于我而言是现在应聘的公司离自己的家更近,又或者是自己工作到达了迷茫期,想跳出迷茫期等等)

Java面试精选题、架构实战文档
整理不易,觉得有帮助的朋友可以帮忙点赞分享支持一下小编~
你的支持,我的动力;祝各位前程似锦,offer不断!
org.springframework.boot
spring-boot-starter-actuator
添加配置文件application-amqp.yml,主要是添加了RabbitMQ的配置及暴露了刷新配置的Actuator端点;
server:
port: 8904
spring:
application:
name: config-server
cloud:
config:
server:
git:
配置存储配置信息的Git仓库
uri: https://gitee.com/JourWon/springcloud-config.git
username: JourWon
password: 123456
开启启动时直接从git获取配置
clone-on-start: true
获取子目录下的配置
search-paths: ‘{application}’
rabbitmq相干配置
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
eureka:
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://localhost:8001/eureka/
暴露bus刷新配置的端点
management:
endpoints:
web:
exposure:
include: ‘bus-refresh’
给config-client添加消息总线支持
在pom.xml中添加相关依赖:
org.springframework.cloud
spring-cloud-starter-bus-amqp
添加配置文件bootstrap-amqp1.yml及bootstrap-amqp2.yml用于启动两个不同的config-client,两个配置文件只有端口号不同;
server:
port: 9004
spring:
application:
name: config-client
cloud:
config客户端配置
config:
分支名称
label: master
启用配置后缀名称
profile: dev
配置文件名称
name: config
discovery:
enabled: true
service-id: config-server
rabbitmq配置
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
eureka:
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://localhost:8001/eureka/
management:
endpoints:
web:
exposure:
include: ‘refresh’
动态刷新配置演示
我们先启动相关服务,启动eureka-server,以application-amqp.yml为配置启动config-server,以bootstrap-amqp1.yml为配置启动config-client,以bootstrap-amqp2.yml为配置再启动一个config-client,启动后注册中心显示如下:

启动所有服务后,我们登录RabbitMQ的控制台可以发现 Spring Cloud Bus 创建了一个叫springCloudBus的交换机及三个以 springCloudBus.anonymous开头的队列:


调用http://localhost:9004/configInfo,结果如下
config info for dev(master)
我们先修改Git仓库中master分支下的config-dev.yml配置文件:
# 修改前信息
config:
info: “config info for dev(master)”
修改后信息
config:
info: “update config info for dev(master)”
调用注册中心的接口刷新所有配置:http://localhost:8904/actuator/bus-refresh

刷新后再分别调用 http://localhost:9004/configInfo 和 http://localhost:9005/configInfo 获取配置信息,发现都已经刷新了;
update config info for dev(master)
如果只需要刷新指定实例的配置可以使用以下格式进行刷新:http://localhost:8904/actuator/bus-refresh/{destination} ,我们这里以刷新运行在9004端口上的config-client为例http://localhost:8904/actuator/bus-refresh/config-client:9004。
WebHooks相当于是一个钩子函数,我们可以配置当向Git仓库push代码时触发这个钩子函数,这里以Gitee为例来介绍下其使用方式,这里当我们向配置仓库push代码时就会自动刷新服务配置了。

结语
小编也是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。
我们选择的这个行业就一直要持续的学习,又很吃青春饭。
虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。
送给每一位想学习Java小伙伴,用来提升自己。

本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!
虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。
送给每一位想学习Java小伙伴,用来提升自己。
[外链图片转存中…(img-s8jKjrP9-1714870401395)]
本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!
本文介绍了SpringCloudConfig在Java面试中的重要性,详细阐述了如何配置和使用ConfigServer、RabbitMQ以及如何利用WebHooks实现配置的动态刷新。作者强调了持续学习和大型互联网架构经验对于提升技术认知的价值。

4万+

被折叠的 条评论
为什么被折叠?



