微服务学习笔记九 Spring Cloud Config本地配置中心

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 微服务学习笔记九 Spring Cloud Config本地配置中心

Spring Cloud Config,通过服务端可以为多个客户端提供配置服务。

Spring Cloud Config可以将配置文件存储在本地,也可以将存储文件存储到远程

Git仓库。

创建Config Serve,通过它管理所有的配置文件。



**本地文件系统**

nativeconfigserver -> application  声明这是存放本地配置文件系统的模块,

具体的存放文件为:nativeconfigserver->configclient-dev.yml。

nativeconfigclient->bootstrap.yml获取configclient-dev.yml中的配置信息

![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20200716152444798.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0OTY5NjQz,size_16,color_FFFFFF,t_70)

![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20200716152459218.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ0OTY5NjQz,size_16,color_FFFFFF,t_70)

创建maven工程,pom.xml


```yaml

<dependencies>

   <dependency>

       <groupId>org.springframework.cloud</groupId>

       <artifactId>spring-cloud-config-server</artifactId>

       <version>2.0.2.RELEASE</version>

   </dependency>

</dependencies>

```


创建application.yml


```yaml

server:

 port: 8762

spring:

 application:

   name: nativeconfigserver

 profiles:

   active: native

 cloud:

   config:

     server:

       native:

         search-locations: classpath:/shared

```


注解说明:

profiles.active:表示的是文件的获取方式

cloud.config.server.native.search-location:本地配置文件存放的路径


resources路径下创建shared文件夹,并在此路径下创建configclient-dev.yml。


```yaml

server:

 port: 8070

foo: foo version 1

```


创建启动类


```java

package com.shuang;


import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.cloud.config.server.EnableConfigServer;


@SpringBootApplication

@EnableConfigServer

public class NativeConfigServerApplication {

   public static void main(String[] args) {

       SpringApplication.run(NativeConfigServerApplication.class,args);

   }

}

```


注解说明:

@EnableConfigServer:声明配置中心

创建客户端,来读取本地配置中心的配置文件

创建maven工程,pom.xml


```yaml

<dependencies>

   <dependency>

       <groupId>org.springframework.cloud</groupId>

       <artifactId>spring-cloud-starter-config</artifactId>

       <version>2.0.2.RELEASE</version>

   </dependency>

</dependencies>

```


创建 bootstrap.yml,配置读取本地配置中心的相关信息。


```yaml

spring:

 application:

   name: configclient

 profiles:

   active: dev

 cloud:

   config:

     uri: http://localhost:8762

     fail-fast: true

```


注解说明;

cloud.config.uri:本地Config Server 的访问路径

cloud.config.fail-fast:设置客户端的优先判断Config Server获取是否正常。

通过 spring.application.name 结合 spring.profiles.active拼接目标配置

文件名,configclient-dev.yml,去Config Server 中查找该文件


创建客户端的启动类:


```java

package com.shuang;


import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;


@SpringBootApplication

public class NativeConfigClientApplication {

   public static void main(String[] args) {

       SpringApplication.run(NativeConfigClientApplication.class,args);

     

   }

}

```


Handler


```java

package com.shuang.controller;


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;


@RestController

@RequestMapping ("/native")

public class NativeConfigHandler {


   @Value("${server.port}")

   private String port;


   @Value("${foo}")

   private String foo;


   @GetMapping("/index")

   public String index(){

       return this.port+"-"+this.foo;

   }

}

```

依次启动:

![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20200716152705432.png)

![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20200716152732747.png)

configclient通过读取configserver的文件,得知端口号为:8070

目录
相关文章
|
11天前
|
JSON Java API
利用Spring Cloud Gateway Predicate优化微服务路由策略
Spring Cloud Gateway 的路由配置中,`predicates`​(断言)用于定义哪些请求应该匹配特定的路由规则。 断言是Gateway在进行路由时,根据具体的请求信息如请求路径、请求方法、请求参数等进行匹配的规则。当一个请求的信息符合断言设置的条件时,Gateway就会将该请求路由到对应的服务上。
112 69
利用Spring Cloud Gateway Predicate优化微服务路由策略
|
3月前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
84 2
|
28天前
|
Java Nacos Sentinel
Spring Cloud Alibaba:一站式微服务解决方案
Spring Cloud Alibaba(简称SCA) 是一个基于 Spring Cloud 构建的开源微服务框架,专为解决分布式系统中的服务治理、配置管理、服务发现、消息总线等问题而设计。
216 13
Spring Cloud Alibaba:一站式微服务解决方案
|
1月前
|
消息中间件 监控 Java
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
36 6
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
130 5
|
1月前
|
Java 关系型数据库 MySQL
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
58 5
|
1月前
|
缓存 监控 Java
如何将Spring Boot应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot应用程序部署到Pivotal Cloud Foundry (PCF)
42 5
|
1月前
|
Prometheus 监控 Java
如何全面监控所有的 Spring Boot 微服务
如何全面监控所有的 Spring Boot 微服务
69 3
|
8月前
|
消息中间件 SpringCloudAlibaba Java
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(八)Config服务配置+bus消息总线+stream消息驱动+Sleuth链路追踪
【Springcloud Alibaba微服务分布式架构 | Spring Cloud】之学习笔记(八)Config服务配置+bus消息总线+stream消息驱动+Sleuth链路追踪
1046 0
|
XML Java 数据库连接
【Spring学习笔记 五】Spring注解及Java类配置开发
【Spring学习笔记 五】Spring注解及Java类配置开发
102 0