SpringCloud学习(五)——SpringCloudConfig分布式配置中心原理与搭建

本文主要是介绍SpringCloud学习(五)——SpringCloudConfig分布式配置中心原理与搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SpringCloud主要框架介绍:

  • 服务发现——Netflix Eureka 连接
  • 服务调用——Netflix Feign 连接
  • 熔断器——Netflix Hystrix 连接
  • 服务网关——Netflix Zuul 连接
  • 分布式配置——Spring Cloud Config
  • 消息总线 —— Spring Cloud Bus 连接连接
    学习分布式:
    分布式配置中心
    分布式锁
    分布式任务调度平台
    分布式事务
    分布式日志收集…

1.简介
在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所
以需要分布式配置中心组件。组件中分两个角色,一是config server,二是config client。
Config Server:是一个可横向扩展、集中式的配置服务器,用于集中管理应用程序各个
环境下的配置。
Config Client:是Config Server的客户端,用于操作存储在Config Server中的配置内容。微服务在启动时会请求Config Server获取配置文件的内容,请求到后再启动容器。
2.什么是分布式配置中心(在微服务中使用)
在微服务当中使用同一个服务管理所有服务配置文件信息,能够实现后台可管理,当服务正在运行时如果配置文件需要改变,可以实现不需要重启服务实时更改配置文件信息。
3.分布式配置中心框架有哪些(3种方案):
阿波罗Apollo(大多采用)(携程的,有图形界面管理,配置文件存放在数据库里)、
SpringCloudConfig(没有图形化后台管理的,配置文件存放在版本控制器里git|svn)、
Zookerper(有持久节点+时间通知)

分布式配置中心需要哪些组件:
(1)web管理系统-----后台可以使用图形界面管理配置文件(SpringCloudConfig没有)
(2)存放分布式配置文件服务器(持久存储服务器) ----使用版本控制器存放比如git|svn
(3)ConfigServer缓存配置文件服务器(临时缓存存放)
(4)ConfigClient读取ConfigServer配置文件信息
4.分布式配置中心设计原理
2.搭建步骤
(1)注册一个码云,创建项目XXX-config
(2)上传配置文件,可将base微服务的的application.yml改名为base-dev.yml后上传
文件命名规则:
{application}-{profile}.yml或{application}-{profile}.properties
application为应用名称 profile指的开发环境(用于区分开发环境,测试环境、生产环境)
(3)配置中心微服务 XXX_config ,pom.xml引入依赖

<dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency>
</dependencies>

(4)创建启动类XXApplication

@EnableConfigServer //开启配置服务
@SpringBootApplication
public class XXApplication {public static void main(String[] args) {SpringApplication.run(ConfigServerApplication.class, args);}
}

(5)编写配置文件application.yml,uri为Gitee创建项目后的路径

server:port: 11000
spring:application:name: XXX-configcloud:config:server:git:uri: https://gitee.com/aa_admin/XXX-config.git

(6)浏览器测试:http://localhost:11000/base-dev.yml 可以看到配置内容
(7)配置客户端
1.在XXX_base工程添加依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId>
</dependency>

2.添加bootstrap.yml ,删除application.yml。因为XXX_base的配置文件已经在Gitee了,添加bootstrap.yml是为了能找到它,根据name和profile即可到配置中心找指定文件

spring:cloud:config:name: baseprofile: devlabel: masteruri: : http://127.0.0.1:12000

3.项目中其余微服务类似修改上传,只需要修改name和profile

这篇关于SpringCloud学习(五)——SpringCloudConfig分布式配置中心原理与搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/238224

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr