1 缘起

微服务的学习过程中,发现了许多服务的配置是相同的,并且项目稳定运行期间不会轻易变更,
于是,自己开始做实验,将这些相同的配置提取出来放在配置中心,
各个服务需要时,通过这个配置中心获取,SpringCloud提供的配置中心组件config,
即是提供中心化配置的组件,方便管理配置文件,
当然,也涉及到配置文件更新的问题,
不过,本文主要讲解如何搭建配置中心,并从配置中心获取配置文件,
没有讲解如何刷新配置参数,会在后续的文章中分享,
本文主要帮助读者从整体架构上理清配置中心的位置以及作用,
并结合实践,搭建相关服务,帮助读者从工程实现上使用配置中心。

2 架构

配置中心的作用:为其他客户端提供公用的配置参数,
简单的测试系统架构如下图所示,由图可知,系统有三个部分:
注册中心、Config服务端和其他的任意客户端,
其中,Config服务端和其他客户端均向注册中心注册,
这样,客户端通过注册中心以及指定的Config服务端serviceId即可获取Config服务端信息,
以获取Config服务端提供的公用配置信息。


注册中心使用Eureka,Config配置中心的服务ID为config,在其他客户端中可以通过serviceId指定config,
获取到该Config服务端的相关信息,Config服务IP和端口,以及公用配置的数据,服务启动后的状态如下图所示。

3 Config服务端配置

3.1 依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId><version>2.2.3.RELEASE</version>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId>
</dependency>

3.2 参数配置

本文的配置中心采用读取本地配置文件的方式,
因此,核心配置的有:spring.profiles.active使用native,
spring.cloud.config配置使用navtive,具体的配置如下:
配置文件存储在resources路径,因此,使用classpath作为前缀。

spring:application:name: config # 配置中心服务名称profiles:active: native # 读取本地配置文件sleuth:sampler:probability: 1.0enabled: truecloud:config:server:native:search-locations: classpath:/config/ # 本地文件:resource目录
server:port: 9002servlet:session:timeout: PT10Seureka: # 连接注册中心client:fetch-registry: trueregister-with-eureka: trueservice-url:defaultZone: http://localhost:8001/eureka/eureka

3.3 启动配置

启动文件添加Config服务端启动注解@EnableConfigServer,
以启用Config服务端,加载相关config配置参数,配置样例如下:

package com.monkey.config;import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;/*** 启动类.** @author xindaqi* @date 2021-04-30 18:22*/
@SpringBootApplication
@EnableConfigServer
public class ConfigApplication {private static final Logger logger = LoggerFactory.getLogger(ConfigApplication.class);public static void main(String[] args) {SpringApplication.run(ConfigApplication.class, args);logger.info(">>>>>>>>Config启动成功");}
}

3.4 资源文件

resources路径添加待共用的配置文件:application-dev.yml,
以对其他客户端提供数据。

spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/db_monkey_run?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghaiusername: rootpassword: 123456type: com.alibaba.druid.pool.DruidDataSourcedruid:initial-size: 10max-active: 100min-idle: 10max-wait: 6000filters: stat, wallstat-view-servlet:enabled: truelogin-username: adminlogin-password: 123456server:port: 9125servlet:session:timeout: PT10S

3.5 获取配置文件

Config服务端启动后,可以通过前缀+后缀的方式获取配置文件内容,
其中,前缀和后缀使用中划线分割,如application-dev.yml,读取文件样例:
http://ip:port/application/dev,
获取的文件内容如下图所示,说明配置中心服务端正常启动并可以对外提供配置数据。

4 客户端配置

4.1 依赖

<!-- 服务注册和发现、客户端负载均衡、熔断 -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId><version>2.2.3.RELEASE</version>
</dependency>
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-client</artifactId>
</dependency>

4.2 参数配置

主要是配置配置中心参数,如开启发现配置中心,以及使用哪个配置中心以及对应的配置文件,
详细配置如下:

spring:cloud:config:discovery:enabled: true # 开启发现spring-config服务service-id: config # spring-config服务IDname: application # spring-config服务中的配置文件前缀profile: dev # spring-config服务中的配置文件后缀,完整:application-dev.ymleureka:client:fetch-registry: trueregister-with-eureka: trueservice-url:defaultZone: http://localhost:8001/eureka/eureka

4.3 读取配置文件

通过接口读取公用的配置文件,
这里读取数据源的地址,
测试接口如下:

package com.monkey.common.api;import com.monkey.common.common.response.Response;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/*** 配置数据接口.** @author xindaqi* @since 2022-10-28 17:46*/
@RestController
@RequestMapping("/api/v1")
public class ConfigDataApi {@Value("${spring.datasource.url}")String datasourceUrl;@GetMapping("/datasource/url")public Response<String> getDatasourceUrl() {return Response.success(datasourceUrl);}
}

测试结果如下图所示,由图可知,客户端正常获取配置中心数据。

5 小结

(1)配置中心的作用:为其他客户端提供公用的配置参数;
(2)通过注册中心获取配置中心信息。

实践讲解Spring配置中心config(图+文,本地文件方式)相关推荐

  1. iframe的src动态修改并刷新_微服务中配置中心Config+消息总线Bus,实现分布式自动刷新配置

    技术/杨33 一.分布式配置中心Config 一套集中的.动态的配置管理,实现统一配置微服务中的每个子服务. Spring Cloud Config为微服务架构提供了集中化的外部配置支持,配置服务器为 ...

  2. 六、springcloud之配置中心Config

    一.配置中心提供的核心功能 Spring Cloud Config为服务端和客户端提供了分布式系统的外部化配置支持.配置服务器为各应用的所有环境提供了一个中心化的外部配置.它实现了对服务端和客户端对S ...

  3. springcloud 分布式配置中心 config server config client

    ---------------------------------------------------------------------------------------------------- ...

  4. 分布式配置中心-Config

    文章目录 一.常规的配置设置方式 1.传统配置管理的缺点 二.分布式配置中心--Config 1.Config的配置文件命名规则 2.config小demo (1)前期准备 1)创建一个git项目 2 ...

  5. Spring Cloud第六章:配置中心Config

    在上一篇文章讲述zuul的时候,已经提到过,使用配置服务来保存各个服务的配置文件.它就是Spring Cloud Config. 一.简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管 ...

  6. 【Spring Cloud】配置中心-Config

    1. 分布式系统面临的问题–配置问题 在分布式系统中,由于服务数量巨多,每个服务的粒度相对较小,而且每个服务都需要必要配置信息才能运行.为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组 ...

  7. spring cloud 2020.0.3 学习记录(四)配置中心config以及bus实现自动配置更新

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一.依赖 二.config 1.server端 2.client端 三.cloud bus实现配置自动更新 加入依赖 更新 ...

  8. 微服务架构spring cloud - 分布式配置中心config(七)

    1.什么是spring-cloud-config 用来为分布式系统中的基础设施和微服务应用提供集体化的外部配置支持,它分为服务端和客户端.服务端也就是config服务,客户端就是其他的微服务. spr ...

  9. SpringCloud教程-分布式配置中心Config (SpringCloud版本Greenwich.SR4)

    文章目录 Config(分布式配置中心)简介 创建服务端ConfigServer 创建客户端config-client 代码地址: github-spring-cloud地址 Config(分布式配置 ...

最新文章

  1. 多协议标签交换中的标签指的是什么?—Vecloud微云
  2. go 多线程并发 queue demo
  3. CTR预估中GBDT与LR融合方案
  4. [转]I,P,B帧和PTS,DTS的关系
  5. flex java框架_fleXive——JavaEE框架
  6. 渝粤教育 陕西师范大学 《金融中介学Ⅰ》作业
  7. Android端发送字符到Wed端,android应用端向web端获取字符串。
  8. BZOJ_1601_[Usaco2008_Oct]_灌水_(最小生成树_Kruskal)
  9. 8.0强行转换后变成了7_血糖7至8正常吗?控制标准不能一概而论,看你的血糖应该在多少...
  10. 改文案、删微博又道歉 广汽蔚来自导自演“比特币购车”乌龙案
  11. 百度之星2018资格赛t6三原色图(MST minimum spanning tree)
  12. Springboot整合junit单元测试
  13. Word技能-更改 Normal 模板 (Normal.dotm)
  14. java之uml类图的介绍
  15. 华为电脑和手机一碰传_华为手机怎么一碰传连接电脑传输照片和文件
  16. 双曲余弦函数实现(C语言)
  17. 将linux系统移动硬盘,着手打造你的随身系统---将linux装进移动硬盘
  18. 伊斯坦布尔之旅第一天:蓝色清真寺和圣索菲亚博物馆
  19. 基于android校园新闻APP开发的设计与实现
  20. Python爬虫 带你一键爬取LOL英雄皮肤壁纸

热门文章

  1. android加载本地图库,Android读取本地图库与调用摄像头拍摄
  2. 程序员求职面试谈工资的技巧 + 防坑指南
  3. 计算机网络-传输层(传输层概述,TCP,UDP协议概述)
  4. Netgear R6220桥接组网设置
  5. 海外专利紧缺 中国IT企业国际化维艰
  6. 英语语法:名词性从句讲解
  7. Ubuntu zhuang SSH
  8. 算法 博弈论( 初级Nim游戏)
  9. 2020 多校联盟(第一场)
  10. ACM DP FatMouse and Cheese