Spring Config 为什么出现
当服务模块增多时要修改一些服务模块相同的配置信息,没有这个config服务模块时,要各个服务模块一个一个的改,为了实现修改一处其的也会跟着变的功能开发出Config服务模块,这个也是一个要注册到服务中心的springboot项目。
Spring Config 怎么实现
将其分为服务端和客户端,服务端负责查看git上的配置文件,多个客户端查看一个服务端的信息。服务端就是Config服务模块,而客户端是各个业务模块服务。
Spring Config 服务端搭建
- git上添加一个仓库
- 新建sprngboot项目,添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
- 设置yml文件
server:
port: 3344
spring:
application:
name: cloud-config-center #注册进Eureka服务器的微服务名
cloud:
config:
server:
git:
uri: git@github.com:zzyybs/springcloud-config.git #GitHub上面的git仓库名字
####搜索目录
search-paths:
- springcloud-config
####读取分支
label: master
#服务注册到eureka地址
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka
- 启动类激活注解
@SpringBootApplication
@EnableConfigServer
public class ConfigCenterMain3344
{
public static void main(String[] args) {
SpringApplication.run(ConfigCenterMain3344.class, args);
}
}
- 修改hosts文件 增加映射
localhost config-3344.com
- 启动项目
访问 config-3344.com:3344/master/config-dev.yml 是否可以访问,其中master代表分支,config-dev.yml 代表配置文件名。
访问 config-3344.com:3344/config-dev.yml 是默认访问master分支。
Spring Config 客户端搭建
即业务模块服务项目的配置信息怎么也跟着git上变
- 添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
- 添加bootstrap.yml文件,这个文件的优先级比application.yml文件优先级高。 设置号分支,名称,环境,配置中心地址等信息。
server:
port: 3355
spring:
application:
name: config-client
cloud:
#Config客户端配置
config:
label: master #分支名称
name: config #配置文件名称
profile: dev #读取后缀名称 上述3个综合:master分支上config-dev.yml的配置文件被读取http://config-3344.com:3344/master/config-dev.yml
uri: http://localhost:3344 #配置中心地址k
#服务注册到eureka地址
eureka:
client:
service-url:
defaultZone: http://localhost:7001/eureka
- 启动类添加注解 注意这个没有config客户端相关注解
@EnableEurekaClient
@SpringBootApplication
public class ConfigClientMain3355
{
public static void main(String[] args) {
SpringApplication.run(ConfigClientMain3355.class, args);
}
}
- 业务类获取配置文件的配置信息
@RestController
public class ConfigClientController
{
@Value("${config.info}")
private String configInfo;
@GetMapping("/configInfo")
public String getConfigInfo()
{
return configInfo;
}
}
config.info 是配置文件内容
启动类查看是否成功获取到对应配置信息。
请求地址:local host:3355/configinfo 对应的业务请求
Spring Config 动态配置问题
- 当git上的配置文件内容修改后 服务端获取对应配置是可以立刻获取到修改后的信息,但是客户端不能立刻获取到修改值,要重启后才可以获取到修改后的值。
解决上述问题方法 实现不重启也可以更新 - 添加依赖 将自己暴露出去,可以被监听到
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
- 修改yml文件 暴露端口
# 暴露监控端点
management:
endpoints:
web:
exposure:
include: "*"
- 业务使用类上添加刷新注解
- 在github上修改配置文件信息 后要调用一下客户端的刷新请求
curl -X POST "http://localhost:3355/actuator/refresh"
其对应的配置信息会相应的改变。这种是手动刷新的操作
Spring Config 自动刷新
这种要使用消息总线配合RabbitMQ的广播模式来批量通知或者精确通知。
- 服务端添加依赖
<!--添加消息总线RabbitMQ支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
- yml添加配置
#rabbitmq相关配置
spring:
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
##rabbitmq相关配置,暴露bus刷新配置的端点
management:
endpoints: #暴露bus刷新配置的端点
web:
exposure:
include: 'bus-refresh'
- 客户端添加依赖
<!--添加消息总线RabbitMQ支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
- yml添加配置
#rabbitmq相关配置 15672是Web管理界面的端口;5672是MQ访问的端口
spring:
rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
# 客户端bus暴露监控端点
management:
endpoints:
web:
exposure:
include: "*"
- 这样修改git上配置文件信息,只要调一下config服务端的刷新请求即可 统一更新config客户端的配置信息
curl -X POST "http://localhost:3344/actuator/bus-refresh
要全部config客户端更新时刷新config服务端即可,要更新单个config客户端就要调用对应的地址的刷新请求即可。
例如:只更新3355 config-client 是微服务名称 application-name 3355是端口号。
curl -X POST "http://localhost:3344/actuator/bus-refresh/config-client:3355
以上为目前看到的信息整理。