6、如何获取配置中心的配置

简介: 本篇将和大家看看如何编写一个Config Client从Config Server获取配置。

如何获取配置中心的配置


在《配置中心》这一篇博文里学习了如何git获取配置文件。大概的流程可以用下图来概括。


微信图片_20220501130612.png


 

《配置中心》这篇博文说的是Config Server,本篇将和大家看看如何编写一个Config Client从Config Server获取配置。


1、先在仓库中创建如下配置文件(具体参考下面地址)


https://gitee.com/hjj520/spring-cloud-2.x/tree/master/config-repos/sc-config-client


2、创建maven项目sc-config-client,对应的pom.xml如下


<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>spring-cloud</groupId>
   <artifactId>sc-config-client</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>sc-config-client</name>
   <url>http://maven.apache.org</url>
   <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>2.0.4.RELEASE</version>
   </parent>
   <dependencyManagement>
      <dependencies>
        <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-dependencies</artifactId>
           <version>Finchley.RELEASE</version>
           <type>pom</type>
        </dependency>
      </dependencies>
   </dependencyManagement>
   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
      <maven.compiler.source>1.8</maven.compiler.source>
      <maven.compiler.target>1.8</maven.compiler.target>
   </properties>
   <dependencies>
      <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-config</artifactId>
        <version>2.0.1.RELEASE</version>
      </dependency>
      <!--
      <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-config-client</artifactId>
        <version>2.0.1.RELEASE</version>
      </dependency>
       -->
      <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
      <dependency>
        <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        <version>2.0.1.RELEASE</version>
      </dependency>
   </dependencies>
</project>


其中:spring-cloud-starter-config与spring-cloud-config-client可以二选一,但是根据选择的依赖不同对应的配置文件有些许不一样。spring-cloud-starter-config已经包含spring-cloud-config-client,所以选择依赖spring-cloud-starter-config。


微信图片_20220501130732.png


3、 创建配置文件bootstrap.yml


#服务端口
server:
  port: 8200
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:5001/eureka/
spring:
  application:
    name: sc-config-client
  cloud:
    config:
      label: master # 配置文件所在分支
      #uri: http://127.0.0.1:8100/  #配置服务中心
      profile: dev  # dev根据具体情况来修改
      discovery:
        serviceId: sc-config-server #配置服务实例名称
        enabled: true  #开启配置服务发现


备注:sc-config-server为配置服务实例名称,对应sc-config-server项目的bootstrap.yml配置文件的如下配置项

 

4、创建启动类ConfigClientApplication.java


package sc.config.client;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@SpringBootApplication
//@EnableDiscoveryClient
@EnableEurekaClient
public class ConfigClientApplication {
   public static void main(String[] args) {
      SpringApplication.run(ConfigClientApplication.class, args);
   }
}


5、为了验证是否能不能在config server获取到配置项,创建一个restful类型的controller:ConfigController.java


package sc.config.client.controller;
import java.util.HashMap;
import java.util.Map;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class ConfigController {
   // git配置文件里的key
   @Value("${jdbc.driverClassName}")
    private String driverClassName;
   @Value("${jdbc.url}")
    private String url;
   @Value("${jdbc.username}")
    private String username;
   @Value("${jdbc.password}")
    private String password;
   @RequestMapping(value="/config/getValue")
   public Map<String, Object> getConfigFromGit() {
      Map<String, Object> result = new HashMap<String, Object>();
      result.put("code", "000000");
      result.put("msg", "ok");
      Map<String, Object> body = new HashMap<String, Object>();
      body.put("driverClassName", driverClassName);
      body.put("url", url);
      body.put("username", username);
      body.put("password", password);
      result.put("body", body);
      return result;
   }
}


6、先启动注册中心,对应的项目为sc-eureka-server;再启动config sever,对应的项目为sc-config-server。然后验证一下config sever是否启动成功


方式一:访问注册中心,可以看到config sever已经注册到注册中心了


微信图片_20220501131012.png


方式二:访问配置文件对应的路径看看是否可以获取配置文件,如果能获取到说明启动成功


微信图片_20220501131015.png


给大家一一对应一下yml问下的访问方式,这些在config server那篇博文只是大概提了一下:


{[/{name}-{profiles}.yml || /{name}-{profiles}.yaml],methods=[GET]}:

http://127.0.0.1:8100/application-dev.yml

{[/{name}/{profiles:.*[^-].*}],methods=[GET]}:

http://127.0.0.1:8100/application/dev

{[/{name}/{profiles}/{label:.*}],methods=[GET]}: http://127.0.0.1:8100/application/dev/master

{[/{label}/{name}-{profiles}.yml || /{label}/{name}-{profiles}.yaml],methods=[GET]}:

http://127.0.0.1:8100/master/application-dev.yml

 

7、启动config client对应的项目sc-config-client


当spring.cloud.config.profile的值为dev时访问http://127.0.0.1:8200/config/getValue


微信图片_20220501131212.png


当spring.cloud.config.profile的值为prd时访问http://127.0.0.1:8200/config/getValue


微信图片_20220501131214.png


可以看到spring.cloud.config.profile配置不一样时,分配获取到git仓库的application-dev.yml和application-prd.yml配置文件的内容

相关文章
|
前端开发 NoSQL Java
Nacos 配置中心实际运用场景以及配置优先级简要概述
Nacos 配置中心实际运用场景以及配置优先级简要概述
659 0
|
1月前
|
存储 缓存 算法
什么是配置中心页面?
【10月更文挑战第24天】什么是配置中心页面?
57 3
|
5月前
|
监控 Serverless 数据处理
函数计算产品使用问题之如何解决配置模型管理的自定义域名后无法访问
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
7月前
|
监控 安全 API
邮件推送API建议操作方法?AOKSend配置步骤
邮件推送API在数字营销中至关重要,本文介绍了其操作建议和AOKSend配置步骤。选择可靠服务如AOKSend、SendGrid、Mailgun,管理API密钥,使用SSL/TLS加密,实现错误处理和重试机制,以及监控邮件发送效果。AOKSend配置包括:注册登录、获取API密钥、配置SMTP设置、测试发送和创建API请求。正确配置能提升营销和沟通效率。
|
7月前
|
弹性计算 运维 Nacos
nacos常见问题之配置中心加密
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
274 4
|
负载均衡 Java Nacos
Nacos注册中心有几种调用方式?
Nacos注册中心有几种调用方式?
120 2
Nacos注册中心有几种调用方式?
|
7月前
|
存储 JSON API
钉钉如何获取调用「创建或更新审批表单模板」接口所需的访问凭证?
钉钉如何获取调用「创建或更新审批表单模板」接口所需的访问凭证?
92 0
|
安全 API 数据安全/隐私保护
云安全中心-云平台配置检查CIEM查询到的Ram相关的检查项,能否在阿里云OpenAPI查到同样的?
云安全中心-云平台配置检查CIEM查询到的Ram相关的检查项,能否在阿里云OpenAPI查到同样的?
124 1
应用中心——应用中心如何使用
应用中心——应用中心如何使用自制脑图
87 0
应用中心——应用中心如何使用
|
7月前
|
存储 安全 关系型数据库
事件中心+Config+函数计算过滤多账号资源配置变更
本文以多账号内RAM角色修改(新增RAM角色、修改RAM角色配置、删除RAM角色)为场景,提供一种基于事件总线 + Config + 函数计算实现特定资源配置过滤。
130 0
事件中心+Config+函数计算过滤多账号资源配置变更