当前位置: 首页 > news >正文

配置中心Config

引入依赖

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>2.0.6.RELEASE</version>

</parent>

<properties>

<spring-cloud.version>Finchley.SR2</spring-cloud.version>

</properties>

<dependencies>

<!-- Eureka-Client 依赖 -->

<dependency>

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

<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>

</dependency>

<!-- Config-Server 依赖 -->

<dependency>

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

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

</dependency>

</dependencies>

<dependencyManagement>

<dependencies>

<!-- SpringCloud 版本控制依赖 -->

<dependency>

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

<artifactId>spring-cloud-dependencies</artifactId>

<version>${spring-cloud.version}</version>

<type>pom</type>

<scope>import</scope>

</dependency>

</dependencies>

</dependencyManagement>

启动类:

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

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

@SpringBootApplication

@EnableConfigServer

public class ConfigCenterApplication {

public static void main(String[] args) {

SpringApplication.run(ConfigCenterApplication.class, args);

}

}

添加配置:application.yml

server:

port: 9001

spring:

application:

name: config-center

eureka:

client:

serviceUrl:

defaultZone: http://localhost:8761/eureka/

创建Git仓库

配置Git仓库

spring:

cloud:

config:

server:

git:

uri: https://gitee.com/pengjunlee/config-cloud.git

username: 你的码云账号

password: 你的账号密码

搭建客户端

引入依赖

<!-- Starter-Config 依赖 -->

<dependency>

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

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

</dependency>

修改配置

先将product-service中的application.yml文件改名为bootstrap.yml(bootstrap.yml在应用上下文启动阶段加载,比application.yml早),然后再对其内容进行修改:

# 设置服务(应用)名称

spring:

application:

name: product-service

# 指定用于获取配置的配置中心服务(应用)名称

cloud:

config:

discovery:

enabled: true

serviceId: config-center

profile: dev

# 指定分枝版本,默认为master

label: master

# 指定注册中心地址

eureka:

client:

serviceUrl:

defaultZone: http://localhost:8761/eureka/

在Git仓库创建配置文件

客户端通过发送Http请求来从配置中心读取配置,这些Http请求的URI遵循以下规则:

/{name}-{profiles}.properties

/{name}-{profiles}.yml || /{name}-{profiles}.yaml

/{label}/{name}-{profiles}.properties

/{label}/{name}-{profiles}.json

/{name}/{profiles}/{label:.*}

/{name}-{profiles}.json

/{label}/{name}-{profiles}.yml || /{label}/{name}-{profiles}.yaml

/{name}/{profiles:.*[^-].*}

/{name}/{profile}/{label}/**

/{name}/{profile}/{label}/**

/{name}/{profile}/**

其中各个参数的含义如下:

name 服务的ID,即spring.application.name的值,本例中为 product-service;

profiles 激活的profile,通过spring.cloud.config.profile指定,本例中为 dev;

label 分枝的版本,通过spring.cloud.config.label指定,本例中为默认值 master;

接下来我们需要按照上述规则,在Git仓库的相应位置创建配置文件。根据bootstrap.yml中的配置,资源请求地址可以为 /master/product-service-dev.yml 。

在Git仓库的master分枝中创建product-service-dev.yml和product-service-test.yml两个文件,分别将服务的启动端口指定为8771和8772:

# product-service-dev.yml

server:

port: 8771

# product-service-test.yml

server:

port: 8772

文件创建完成之后,启动配置中心,先在浏览器对两个文件进行访问。

此时,启动product-service将读取http://localhost:8888/product-service-dev.yml中的配置,即启动端口为8771。若将 bootstrap.yml中的spring.cloud.config.profile的值设置为test,则将读取http://localhost:8888/product-service-test.yml中的配置,应用的启动端口也会相应地变为8772,证明从配置中心读取配置成功。

http://www.lryc.cn/news/7784.html

相关文章:

  • 【原创】java+jsp+servlet学生信息管理系统(jdbc+ajax+filter+cookie+分页)
  • 链表题目总结 -- 回文链表
  • JAVA集合之List >> Arraylist/LinkedList/Vector结构
  • Linux多进程开发
  • 三维重建小有基础入门之特征点检测基础
  • 基于node.js+vue+mysql考研辅导学习打卡交流网站系统vscode
  • 【C++、数据结构】封装unordered_map和unordered_set(用哈希桶实现)
  • StratoVirt 的 vCPU 拓扑(SMP)
  • 现在直播大部分都是RTMP RTMP VS RTC
  • 【Unity实战100例】Unity循环UI界面切换卡片功能
  • Monorepo or 物料市场?结合工作实际情况对公司现有前端体系的思考
  • GEE学习笔记八十八:在自己的APP中使用绘制矢量(上)
  • “笨办法”学Python 3 ——练习 39. 字典,可爱的字典
  • 模糊的照片如何修复清晰?
  • 如何理解​session、cookie、token的区别与联系?
  • 【MyBatis】| MyBatis分页插件PageHelper
  • Java枚举类详解
  • C语言数组
  • Scala 入门(第一章Scala 环境搭建、插件的安装)
  • math@多项式@求和式乘法@代数学基本定理
  • Kafka系列之:基于SCRAM和Ranger机制完成动态新增kafka读写账号、赋予账号对指定Topic的读写权限
  • 第五十三章 DFS进阶(一)——剪枝优化
  • Java字节码深度知多少?
  • 【C++】智能指针(万字详解)
  • 使用docker配置mysql主从复制
  • v3 异步组件及分包使用
  • 实用调试技巧【上篇】
  • JavaScript 教程
  • 在SpringBoot里面使用原生的Servlet
  • 商标被驳回,先别慌!挽回商标有办法