当前位置: 首页 > 编程笔记 >

SpringCloud-Config分布式配置代码示例

魏元白
2023-03-14
本文向大家介绍SpringCloud-Config分布式配置代码示例,包括了SpringCloud-Config分布式配置代码示例的使用技巧和注意事项,需要的朋友参考一下

概述

Spring Cloud Config为分布式系统中的外部化配置提供服务器端和客户端支持。使用Config Server,您可以在中心位置管理所有环境中应用程序的外部属性。客户端和服务器上的概念都与Spring Environment和PropertySource抽象映射相同,因此它们非常适合Spring应用程序,但可以与以任何语言运行的任何应用程序一起使用。

在应用程序从开发人员到测试人员再到生产人员的整个部署过程中,您可以管理这些环境之间的配置,并确保应用程序具有它们迁移时所需的一切。服务器存储后端的默认实现使用git,因此它轻松支持带标签的配置环境版本,并且可以通过各种工具来访问这些内容来管理内容。添加替代实现并将其插入Spring配置很容易。

•去码云创建仓库,克隆到本地文件夹,配置application.yml文件

  •application.yml配置

spring:
 profiles:
  active: dev

---
spring:
 profiles: dev
 application:
  name: springcloud-config-dev

---
spring:
 profiles: test
 application:
  name: springcloud-config-test

  •把这个文件提交到码云上,总共四步。

  第一步:

    把文件添加到暂存区    

git add

   在这里添加

    第二步:

      查看状态

git status

   第三步:

提交

git commit -m "fist commit" //fist commit是描述信息

   第四步:

      push到远程

git push origin master

   测试:成功

 •创建服务端Server项目

  •导入依赖

<dependencies>
    <!--config-->
    <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-config-server -->
    <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-config-server</artifactId>
      <version>2.1.1.RELEASE</version>
    </dependency>
    <!--actuator完善监控信息-->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

  </dependencies>

  •编写配置

server:
 port: 3344
spring:
 application:
  name: springcloud-congi-server
  #连接远程仓库
 cloud:
  config:
   server:
    git:
     uri: https://gitee.com/springandspring/springcloud-config.git #这里的uri是码云上自己创建的仓库HTTPS下载的地址

  •开启功能

@EnableConfigServer

  •测试

  •更上面一样

  •config-client配置

spring:
 profiles:
  active: dev

---
server:
  port: 8201
#spring的配置
spring:
 profiles: dev
 application:
  name: springcloud-provider-dept

#Eureka的配置,服务注册到哪里
eureka:
 client:
  service-url:
   defaultZone: http://eureka7001.com:7001/eureka/


---
server:
  port: 8202
#spring的配置
spring:
 profiles: test
 application:
  name: springcloud-provider-dept

#Eureka的配置,服务注册到哪里
eureka:
 client:
  service-url:
   defaultZone: http://eureka7001.com:7001/eureka/

  •执行上面的四步,push到远程

  •创建一个client客户端新项目

  •导入依赖

<dependencies>

    <!--config-->
    <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-config -->
    <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-config</artifactId>
      <version>2.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
  </dependencies>

  •编写bootstrap配置  

#系统级别的配置 比用户级别设置先执行
spring:
 cloud:
  config:
   profile: dev   #生产环境
   name: config-client     #需要从git上读取的资源名称,不需要后缀
   label: master
   uri: http://localhost:3344 #连接服务端的地址
   #相当于http://localhost:3344/master/config-client-dev/master

  编写application配置

#用户级别的设置
spring:
 application:
  name: springcloud-config-client-3355

  •编写启动类

 •编写Controller

@RestController
public class ConfigClientController {
  @Value("${spring.application.name}")
  private String applicationName;
  @Value("${eureka.client.service-url.defaultZone}")
  private String eurekaServer;
  @Value("${server.port}")
  private String port;

  @RequestMapping("/config") //请求这个路径获取config-client配置里面的信息
  public String getConfig(){
    return "applicationName"+applicationName+
        "eurekaServer"+eurekaServer+
        "port"+port;
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍SpringCloud之分布式配置中心Spring Cloud Config高可用配置实例代码,包括了SpringCloud之分布式配置中心Spring Cloud Config高可用配置实例代码的使用技巧和注意事项,需要的朋友参考一下 一、简介 当要将配置中心部署到生产环境中时,与服务注册中心一样,我们也希望它是一个高可用的应用。Spring Cloud Config实现服务端的高

  • 简介 Spring cloud config 分为两部门 server client config-server 配置服务端,服务管理配置信息 config-client 客户端,客户端调用server端暴露接口获取配置信息 config-server 创建config-server 首先创建config-server工程. 文件结构: ├── config-server.iml ├── po

  • Zookeeper提供了一个分层命名空间,允许客户端存储任意数据,如配置数据。Spring Cloud Zookeeper Config是Config Server和Client的替代方案。在特殊的“引导”阶段,配置被加载到Spring环境中。默认情况下,配置存储在/config命名空间中。根据应用程序的名称和模拟解析属性的Spring Cloud Config顺序的活动配置文件,创建多个Prop

  • 本文向大家介绍springcloud config配置读取优先级过程详解,包括了springcloud config配置读取优先级过程详解的使用技巧和注意事项,需要的朋友参考一下 情景描述 最近在修复Eureka的静态页面加载不出的缺陷时,最终发现是远程GIT仓库将静态资源访问方式配置给禁用了(spring.resources.add-mappings=false)。虽然最后直接修改远程GIT仓库

  • 本文向大家介绍Java编程redisson实现分布式锁代码示例,包括了Java编程redisson实现分布式锁代码示例的使用技巧和注意事项,需要的朋友参考一下 最近由于工作很忙,很长时间没有更新博客了,今天为大家带来一篇有关Redisson实现分布式锁的文章,好了,不多说了,直接进入主题。 1. 可重入锁(Reentrant Lock) Redisson的分布式可重入锁RLock Java对象实现

  • 在分布式系统中,常困扰我们的还有上线问题。虽然目前有一些优雅重启方案,但实际应用中可能受限于我们系统内部的运行情况而没有办法做到真正的“优雅”。比如我们为了对去下游的流量进行限制,在内存中堆积一些数据,并对堆积设定时间或总量的阈值。在任意阈值达到之后将数据统一发送给下游,以避免频繁的请求超出下游的承载能力而将下游打垮。这种情况下重启要做到优雅就比较难了。 所以我们的目标还是尽量避免采用或者绕过上线