SpringCloud-分布式配置中心【入门介绍】
案例代码:https://github.com/q279583842q/springcloud-e-book
一、 为什么需要使用配置中心
1 服务配置的现状
2 常用的配置管理解决方案的缺点
3 为什么要使用 spring cloud config 配置中心?
4 spring cloud config配置中心,它解决了什么问题?
二、 编写配置中心入门案例
1.编写配置中心的服务端
1.1 创建服务端项目
创建一个SpringCloud项目。
1.2 修改pom文件
我们需要添加config-server的依赖,具体如下
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.13.RELEASE</version></parent><groupId>com.bobo</groupId><artifactId>config-server</artifactId><version>0.0.1-SNAPSHOT</version><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Dalston.SR5</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
</project>
1.3 修改配置文件
在此处的配置文件中我们需要关联码云或者GitHub。以码云为例
码云处理
首先我们需要在码云上注册一个账号(https://gitee.com) 然后创建一个新的项目。
配置文件处理
在配置文件中添加如下配置
spring.application.name=config-server
server.port=9050
# 设置服务注册中心地址,指向另一个注册中心
eureka.client.serviceUrl.defaultZone=http://dpb:123456@eureka1:8761/eureka/,http://dpb:123456@eureka2:8761/eureka/#Git 配置
spring.cloud.config.server.git.uri=https://gitee.com/dengpbs/config
#spring.cloud.config.server.git.username=
#spring.cloud.config.server.git.password=
创建四个配置文件
四个配置文件都有一个e-book属性,只是值不一样。然后将这个四个配置文件上传到码云中我们新创建的仓库
然后将项目中的四个配置文件删除
1.4 修改启动类
我们需要在启动类中添加eureka客户端和config服务端的注解,具体如下:
@SpringBootApplication
@EnableEurekaClient
@EnableConfigServer
public class ConfigServerStart {public static void main(String[] args) {SpringApplication.run(ConfigServerStart.class, args);}
}
1.5 访问测试
启动服务,访问测试
http://localhost:9050/config-client/test
http://localhost:9050/config-client/default
http://localhost:9050/config-client/dev
通过访问,我们获取到了位于码云仓库中的属性信息。
1.6 配置文件的命名规则与访问
注意,上面案例中的配置文件的名称,并不是随便命名的,而是有一定的规则来约束的,具体如下:
2.编写客户端程序
2.1 创建项目
创建一个SpringCloud项目
2.2 pom文件修改
配置中心的客户端使用的依赖需要注意,不是config-server了,具体如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.13.RELEASE</version></parent><groupId>com.bobo</groupId><artifactId>config-client</artifactId><version>0.0.1-SNAPSHOT</version><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Dalston.SR5</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-config</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
</project>
2.3 修改配置文件
注意在配置中心的客户端服务中,配置文件的名称必须是bootstrap.properties或者bootstrap.yml文件。
官方解释:
Spring Cloud 构建于 Spring Boot 之上,在 Spring Boot 中有两种上下文,一种是 bootstrap, 另外一种是 application, bootstrap 是应用程序的父上下文,也就是说 bootstrap 加载优先于 applicaton。bootstrap 主要用于从额外的资源来加载配置信息,还可以在本地外部配置文件中解密属性。这两个上下文共用一个环境,它是任何Spring应用程序的外部属性的来源。bootstrap 里面的属性会优先加载,它们默认也不能被本地相同配置覆盖。
spring.application.name=config-client
server.port=9051
#设置服务注册中心地址,指向另一个注册中心
eureka.client.serviceUrl.defaultZone=http://dpb:123456@eureka1:8761/eureka/,http://dpb:123456@eureka2:8761/eureka/#默认 false,这里设置 true,表示开启读取配置中心的配置
spring.cloud.config.discovery.enabled=true
#对应 eureka 中的配置中心 serviceId,默认是 configserver
spring.cloud.config.discovery.serviceId=config-server
#指定环境
spring.cloud.config.profile=dev
#git 标签
spring.cloud.config.label=master
2.4 修改启动类
@SpringBootApplication
@EnableEurekaClient
public class ConfigClientStart {public static void main(String[] args) {SpringApplication.run(ConfigClientStart.class, args);}
}
2.5 创建控制器
在控制中我们尝试获取配置中心的数据,具体如下:
@RestController
public class ShowController {@Value("${e-book}")private String msg;@RequestMapping("/showMsg")public String showMsg(){return msg;}
}
2.6 启动测试
访问:http://localhost:9051/showMsg
搞定~
SpringCloud-分布式配置中心【入门介绍】相关推荐
- springcloud 分布式配置中心 config server config client
---------------------------------------------------------------------------------------------------- ...
- SpringCloud学习(十八):Config分布式配置中心的介绍与搭建
目录 一.概述 1.分布式系统面临的配置问题 2. Config配置中心是什么 3.Spring Config能做什么 二.Config总控中心配置与测试 1.在Gitee上新建仓库 2.本地硬盘目录 ...
- springcloud分布式配置中心(二)-阿波罗apollo
1.Springcloud的分布式配置中心组件 组件一般有两个,springcloud config,apollo.apollo有一个好处是apollo有界面,这是apollo的一个优势. sprin ...
- Apollo分布式配置中心入门
一.概述 1.什么是配置 应用程序在启动和运行的时候往往需要读取一些配置信息,配置基本上伴随着应用程序的整个生命周期,比如:数据库连接参数.启动参数等. 配置主要有以下几个特点: 配置是独立于程序的只 ...
- SpringCloud 分布式配置中心Config Hoxton版本
Spring Cloud Config简介:Spring Cloud Config为分布式系统提供了服务端和客户端用于支持外部配置.使用Config Server可以在所有环境中管理应用程序的外部属性 ...
- SpringCloud: 分布式配置中心(Spring Cloud Config)
简介 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件.在Spring Cloud中,有分布式配置中心组件spring cloud config , ...
- 白话SpringCloud | 第八章:分布式配置中心的服务化及动态刷新
前言 上一章节,简单介绍了分布式配置中心Spring Cloud Config的使用.同时,我们也遗漏了一些问题,比如如何配置实时生效,当服务端地址变更或者集群部署时,如何指定服务端地址?回想,在服务 ...
- springcloud config 分布式配置中心
一.介绍 1.场景: 微服务系统中,系统多.实例多,如果每个系统都有自己一套配置加载.维护的机制,会导致在生产过程中因为配置问题引发的不必要的沟通成本.故障风险.需要采用分布式配置中心统一管理.统一实 ...
- SpringCloud微服务架构,Config 分布式配置中心,Bus 消息总线, Stream 消息驱动,Sleuth+Zipkin 链路追踪
Config分布式配置中心 Config 概述 概述 • Spring Cloud Config 解决了在分布式场景下多环境配置文件的管理和维护. • 好处: • 集中管理配置文件 • 不同环境不同配 ...
- SpringCloud config 配置中心介绍与基本配置使用
一.SpringCloud Config 介绍 出现背景:在微服务架构中,在没有配置中心出现时,我们每个应用的配置信息都在其配置文件application.properties中维护.加入整个系统中有 ...
最新文章
- 搭建php帮助中心,帮助中心
- “网站漏洞”成电信诈骗帮凶 专家呼吁进行“立体防护”
- 041_对象的创建和销毁
- 日志和告警数据挖掘经验谈
- qemu模拟imx6用户态环境
- python相关linux_Python实现获取Linux系统基本信息
- 第21讲:IP代理池的搭建和使用
- Python如何将列表分成均匀大小的块?
- python 同时发多个请求_PythonWebServer如何同时处理多个请求
- 看我如何用Dataphin实现自动化建模
- 探讨 | 深入探讨Redis管道
- 关于Cococs中的CCActionEase(下)
- 数据爆炸时代,云存储在“破圈”!
- 1002:A+B 输入输出练习III 分数: 2
- vscode使用:tab键插入空格而不是tab
- linux添加网络节点,Pi网络节点配置教程(windows10专业版)
- 百度HI QQ和MSN 阿里旺旺贸易通MSN在线客服聊天代码
- spring项目接入flyway(一) 背景、快速入门
- 【2023】浙江大学计算机考研信息汇总
- tcpip Socket编程入门