分布式配置中心SpringCloudConfig

news/2024/12/22 14:17:28/

1 简介

在分布式系统中,由于服务数量较多,配置文件分布在不同的微服务项目中,管理不方便。为了方便对配置文件的集中管理,需要使用分布式配置中心组件。在SpringCloud中,提供了SpringCloud Config,它支持将配置文件放到配置服务的本地,也支持放在远程Git仓库(GitHub或码云等)。
配置中心在本质上也是一个微服务,同样需要注册到Eureka服务注册中心。

2 Git配置管理

2.1 远程Git仓库

知名的Git远程仓库有国外的GitHub和国内的码云(gitee);但是使用GitHub时,国内的用户经常遇到的问题是访问速度太慢,有时候还会出现无法连接的情况。如果希望体验更好一些,可以使用国内的Git托管服务——码云(gitee.com)。
与GitHub相比,码云也提供免费的Git仓库。此外,还集成了代码质量检测、项目演示等功能。对于团队协作开发,码云还提供了项目管理、代码托管、文档管理的服务。本章中使用的远程Git仓库是码云。
码云访问地址

2.2 创建远程仓库

首先要使用码云上的私有远程git仓库需要先注册帐号;请先自行访问网站并注册帐号,然后使用帐号登录码云控制台并创建公开仓库。

2.3 创建配置文件

在新建的仓库中创建需要被统一配置管理的配置文件。
配置文件的命名方式:{application}-{profile}.yml {application}-{profile}.properties
其中:application为应用名称
profile用于区分开发环境,测试环境、生产环境等,如user-dev.yml,表示用户微服务开发环境下使用的配置文件。

3 搭建配置中心微服务

3.1 创建工程

创建config-server配置中心服务模块,添加依赖,

    <dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency></dependencies>

配置启动类

package com.giser.config;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;@SpringBootApplication
@EnableConfigServer
public class ConfigServerApplication {public static void main(String[] args) {SpringApplication.run(ConfigServerApplication.class, args);}
}
3.2 编写配置文件
server:port: 20000spring:application:name: config-serversecurity:user:name: adminpassword: 123cloud:config:server:git:uri: https://gitee.com/giserDev/springcloudconfig.giteureka:client:service-url:defaultZone: http://${spring.security.user.name}:${spring.security.user.password}@127.0.0.1:10086/eureka/
3.3 启动测试

启动配置中心和注册中心,访问http://localhost:20000/application-dev.yml,此时可以输出配置文件内容。并且当配置文件内容发生变化时,可以及时读取到最新数据。

4 获取配置中心配置信息

在完成配置中心微服务的搭建之后,需要改造用户微服务,其配置文件信息不再由微服务项目提供,而实从配置中心获取。此时需要对user-service进行改造。

4.1 添加依赖
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId>
</dependency>
4.2 修改配置

删除application.yml文件,添加bootstrap.yml文件,配置如下:

spring:cloud:config:# 与远程仓库中的配置文件的application保持一致name: application# 远程仓库中的配置文件的profile保持一致profile: dev# 远程仓库中的版本保持一致label: masterdiscovery:# 使用配置中心enabled: true# 配置中心服务idservice-id: config-servereureka:client:service-url:defaultZone: http://127.0.0.1:10086/eureka

bootstrap.yml和application.yml的区别:

bootstrap.yml文件也是Spring Boot的默认配置文件,而且其加载的时间相比于application.yml更早。
application.yml和bootstrap.yml虽然都是Spring Boot的默认配置文件,但是定位却不相同。
bootstrap.yml
可以理解成系统级别的一些参数配置,这些参数一般是不会变动的。
application.yml 
可以用来定义应用级别的参数,如果搭配 spring cloud config 使用,application.yml 里面定义的文件可以实现动态替换。
总结就是:
bootstrap.yml文件相当于项目启动时的引导文件,内容相对固定。
application.yml文件是微服务的一些常规配置参数,变化比较频繁。
4.3 启动测试

启动注册中心eureka-server 、配置中心config-server 、用户服务user-service ,如果启动没有报错其实已经使用上配置中心内容,可以到注册中心查看,也可以检验user-service 的服务。


http://www.ppmy.cn/news/1272329.html

相关文章

Flink系列之:SELECT WHERE clause

Flink系列之&#xff1a;SELECT & WHERE clause 一、SELECT & WHERE clause二、SELECT DISTINCT 适用于流、批 一、SELECT & WHERE clause SELECT 语句的一般语法是&#xff1a; SELECT select_list FROM table_expression [ WHERE boolean_expression ]table_e…

Linux cd命令教程:如何有效地在目录之间切换(附案例详解和注意事项)

Linux cd命令介绍 cd命令是Linux系统中的一个基本命令&#xff0c;全称为change directory&#xff0c;用于改变或切换当前工作目录。 Linux cd命令适用的Linux版本 cd命令在所有的Linux发行版中都是可用的&#xff0c;包括但不限于Ubuntu, Debian, Fedora, CentOS等。 [li…

25个校招网络编程面试题

1、什么是IO多路复用 I/O多路复用的本质是使用select,poll或者epoll函数&#xff0c;挂起进程&#xff0c;当一个或者多个I/O事件发生之后&#xff0c;将控制返回给用户进程。以服务器编程为例&#xff0c;传统的多进程(多线程)并发模型&#xff0c;在处理用户连接时都是开启一…

tp如何开启监听SQL

如果开启数据库的调试模式的话&#xff0c;你可以对数据库执行的任何SQL操作进行监听&#xff0c;使用如下方法 Db::listen(function($sql, $time, $explain){// 记录SQLecho $sql. [.$time.s];// 查看性能分析结果dump($explain); });默认如果没有注册任何监听操作的话&…

实现两张图片的接缝线拼接

使用ORB算法检测特征点&#xff0c;并通过BFMatcher进行特征点匹配。然后&#xff0c;根据Lowes ratio test选择好的匹配点&#xff0c;并使用findHomography计算单应性矩阵。最后&#xff0c;使用warpPerspective将图像进行透视变换&#xff0c;然后将第二张图像粘贴到变换后的…

架构设计系列之常见架构(二)

五、DDD&#xff08;领域驱动设计&#xff09; 领域驱动设计&#xff08;Domain-Driven Design&#xff0c;DDD&#xff09;是一种开发思想&#xff0c;强调将软件系统的注意力集中在业务领域上&#xff0c;将领域视为应用的核心。在架构设计中&#xff0c;DDD 提供了一种不同…

【JAVA日志框架】JUL,JDK原生日志框架详解。

前言 Java日志体系混乱&#xff1f;Java日志框架系列&#xff0c;清晰简洁整理好整个Java的日志框架体系。第一篇&#xff0c;JDK原生日志框架——JUL。 目录 1.概述 2.日志级别 3.配置 4.继承关系 1.概述 日志框架的核心问题&#xff1a; 日志是用来记录应用的一些运行…

PHP的垃圾回收机制是怎样的?

PHP 使用自动垃圾回收机制来管理内存。PHP 的垃圾回收主要依赖于引用计数和周期性垃圾回收两种策略。 引用计数&#xff1a; PHP 使用引用计数来跟踪变量的引用次数。每当一个变量被引用&#xff0c;其引用计数就增加&#xff1b;每当一个引用被释放&#xff0c;计数就减少。当…