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

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.0
    enabled: true
  cloud:
    config:
      server:
        native:
          search-locations: classpath:/config/ # 本地文件:resource目录
server:
  port: 9002
  servlet:
    session:
      timeout: PT10S

eureka: # 连接注册中心
  client:
    fetch-registry: true
    register-with-eureka: true
    service-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.Driver
    url: jdbc:mysql://localhost:3306/db_monkey_run?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    username: root
    password: 123456
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      initial-size: 10
      max-active: 100
      min-idle: 10
      max-wait: 6000
      filters: stat, wall
      stat-view-servlet:
        enabled: true
        login-username: admin
        login-password: 123456

server:
  port: 9125
  servlet:
    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服务ID
      name: application # spring-config服务中的配置文件前缀
      profile: dev # spring-config服务中的配置文件后缀,完整:application-dev.yml
     
eureka:
  client:
    fetch-registry: true
    register-with-eureka: true
    service-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)通过注册中心获取配置中心信息。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天然玩家

坚持才能做到极致

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值