spring-cloud入门之spring-cloud-config(配置中心)
前言
在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件:spring-cloud-config ,它支持配置服务放在配置服务的内存中(即本地),也支持放在远程Git仓库中。
本节主要演示怎么用Git仓库作为配置源。
开源地址:https://github.com/bigbeef
创建配置项目
在github中创建一个项目,专门用来保存我们所有项目的配置文件,项目是我的项目结构
配置项目地址:https://github.com/bigbeef/cppba-config

eureka-server.properties
eureka.client.register-with-eureka=false eureka.client.fetch-registry=false spring.application.name=eureka-server server.port=18761 eureka.instance.hostname=peer1 eureka.client.serviceUrl.defaultZone=http://peer1:18761/eureka/
创建spring-cloud-config-server项目
项目结构如图:

pom.xml核心代码
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
</dependencies>
SpringCloudConfigServerApplication.java
package com.cppba;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
@SpringBootApplication
@EnableConfigServer
public class SpringCloudConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(SpringCloudConfigServerApplication.class, args);
}
}
application.properties
这个根据自己实际的git项目修改配置
server.port=8888 spring.application.name=config-server spring.cloud.config.server.git.uri=https://github.com/bigbeef/cppba-config spring.cloud.config.label=master # spring.cloud.config.server.git.username= # spring.cloud.config.server.git.password= spring.cloud.config.server.git.searchPaths=\ cppba-spring-cloud/*,\ cppba-spring-cloud/eureka-client/*
spring.cloud.config.server.git.uri:配置git仓库地址
spring.cloud.config.server.git.searchPaths:配置仓库路径,以逗号隔开
spring.cloud.config.label:配置仓库的分支
spring.cloud.config.server.git.username:访问git仓库的用户名
spring.cloud.config.server.git.password:访问git仓库的用户密码
启动项目
访问地址:http://127.0.0.1:8888
http请求地址和资源文件映射如下:
/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}-{profile}.properties
/{label}/{application}-{profile}.properties
根据我们自己的配置,我们可以这样访问:http://127.0.0.1:8888/eureka-server/default/master
application -> eureka-server (应用名)
profile -> default (启用的配置,通常是后缀,下面解释)
label -> master (分支)
访问到的结果就是:

profile比较重要,可以理解成读取哪些配置文件,假如我不止一个配置文件,可能会有:
eureka-server.properties(这个是通用配置文件,默认都会加载),
eureka-server-mysql.properties,
eureka-server-oracle.properties,
eureka-server-jpa.properties,
eureka-server-mysql.properties......
我们可能会选择性的加载其中的部分properties配置文件,那我们可以这样写:http://127.0.0.1:8888/eureka-server/default,mysql,jpa/master
到此,我们的spring-cloud-config-server就简单搭起来,后面的章节我会教大家怎么在项目中读取配置
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
spring mvc中@PathVariable / 带斜杠方式获取
这篇文章主要介绍了spring mvc中@PathVariable / 带斜杠方式获取,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-08-08
Java的PriorityBlockingQueue优先级阻塞队列代码实例
这篇文章主要介绍了Java的PriorityBlockingQueue优先级阻塞队列代码实例,PriorityBlockingQueue顾名思义是带有优先级的阻塞队列,为了实现按优先级弹出数据,存入其中的对象必须实现comparable接口自定义排序方法,需要的朋友可以参考下2023-12-12
基于SpringBoot+FastExcel的百万级数据导入导出完整方案
本文详细介绍了在SpringBoot3.5.11+JDK17+MySQL环境下,使用FastExcel实现百万级数据的导入和导出,内容包括数据库表设计、百万测试数据生成、实体类与Mapper、配置文件、百万数据导入、百万数据导出、线程池、阻塞队列、CountDownLatch的设计思路与原理,以及接口测试方法2026-03-03


最新评论