十六、Config分布式配置中心

本文介绍了如何使用Spring Cloud Config搭建分布式配置中心,包括config-server的配置与验证,config-client的设置,以及如何实现在不重启服务的情况下获取配置信息的实时更新。

目录

分布式配置中心概述

1、为什么需要分布式配置中心?

2、配置中心的作用:

Spring Cloud Config简介

 新建项目springcloud-config-server

1、引入配置中心config-server的依赖

2、在github/gitee上新建一个远程仓库作为config的远程配置中心

3、添加application.yml文件

4、添加启动类,在启动类上添加注解@EnableConfigServer

5、验证配置中心服务项目是否搭建成功

 新建项目springcloud-config-client

1、引入config-client依赖

2、添加bootstrap.yml配置文件

3、添加启动类

4、添加Controller获取配置信息

5、启动config-client、config-server,将服务注册到统一个注册中心

6、配置无需重启获得修改后的配置信息

6.1、添加依赖

6.2、修改bootstrap.yml配置内容,添加如下内容

6.3、Controller类上加@RefreshScope注解

6.4、使用postman手动发送一个post请求,主动刷新client端项目

6.5、手动刷新client端项目后,重新访问localhost:9022/getConfig即可看到更新后的配置信息


分布式配置中心概述

1、为什么需要分布式配置中心?

1.1、配置文件无法统一管理,如数据库连接、redis连接、第三方账号信息等等

1.2、无法实时更新

2、配置中心的作用:

2.1统一管理配置信息

使用配置中心管理各个项目的配置信息,而不需要写到每个项目的jar包的resource里,这样修改项目的配置更加方便,否则如果每个项目各自维护自己的配置信息,那么在项目很多的情况下,维护配置信息将是一件令人奔溃的事情

2.2一处修改处处更新

     修改完后,会在项目中自动更新配置信息,而不需要去每台服务器上重启服务

Spring Cloud Config简介

配置中心为了方便服务配置文件的统一管理,实时更新,所以需要分布式配置中心组件,它就是Spring Cloud Config。它支持配置信息放在配置服务的内存中(即本地),也支持放在远程git仓库。在Spring Cloud Config中分为三个角色,一是远程仓库,二是config server,三是config client。

  1. 远程仓库:负责存储配置文件信息
  2. Config server:负责拉取远程仓库上的配置文件信息
  3. Config client:负责从config server读取配置信息

架构图如下:

 新建项目springcloud-config-server

1、引入配置中心config-server的依赖

<!--config server配置中心依赖-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-config-server</artifactId>
</dependency>

2、在github/gitee上新建一个远程仓库作为config的远程配置中心

如:https://gitee.com/xxx/configuration.git

3、添加application.yml文件

server:
  port: 9021

spring:
  application:
    name: config-server
  cloud:
    config:
      server:
        git:
          #git的仓库地址
          uri:  https://gitee.com/xxx/configuration.git
          #文件路径
          search-paths: config
          #username
          #password
#如果仓库是公开仓库,则可以不配置用户名和密码
eureka:
  instance:
    # 使用ip地址作为host,而不是机器号/电脑名称
    prefer-ip-address: true
    #    Eureka客户端向注册中心发送心跳的时间间隔是1s,默认是30s
    lease-renewal-interval-in-seconds: 1
    #    Eureka服务端在收到一次心跳后等待时间上限是2s,默认是90s
    #    超时将剔出该微服务,也可以在Eureka服务端进行设置
    lease-expiration-duration-in-seconds: 2
  client:
    service-url:
      defaultZone: http://localhost:8060/eureka/
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值