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

SpringCloud系列(42)--搭建SpringCloud Config分布式配置总控中心(服务端)

前言:在上一节中我们介绍了什么是SpringCloud Config,SpringCloud Config有什么用,介绍了SpringCloud Config分为服务端和客户端两部分,而在本节我们将首先搭建SpringCloud Config的服务端部分(服务端又被称为分布式配置总控中心)

要搭建的是圈起来的那部分

注:由于SpringCloud Config默认使用Git来存储配置文件(也有其它方式,比如支持SVN和本地文件),但最推荐的还是Git,而且使用的是http/https访问的形式

1、在gitee或者github上新建一个远程仓库(我这里拿gitee来做示范)

2、配置仓库,然后创建仓库

效果图:

3、克隆项目
(1)点击克隆/下载按钮

(2)复制克隆用的命令
(3)进入要存放项目的目录里,然后点击Git Bash Here(注:得先下载Git)

(4)把克隆命令复制到git的命令行里,然后按回车

效果图:

(5)编写一个名为config-dev的yml配置文件,内容如下
config:info: "master branch,springcloud-config/config-dev.yml version=1"

效果图:

(6)把配置文件推送到git上

效果图:

4、创建一个配置中心模块,命名为cloud-config-center-3344
(1)在父工程下新建模块

 (2)选择模块的项目类型为Maven并选择模块要使用的JDK版本

(3)填写子模块的名称,然后点完成即可完成创建

效果图:

(4)修改cloud-config-center-3344子模块的pom.xml文件,然后reolad一下,下载依赖

例:

<?xml version="1.0" encoding="UTF-8"?>
<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"><parent><artifactId>springcloud01</artifactId><groupId>com.ken.springcloud</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>cloud-config-center-3344</artifactId><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency><!--以下依赖都没写版本号,没写版本号的情况下会引用父项目的版本--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--监控--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><!--热部署--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency><!--lombok插件--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!--Eureka Clinet--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency></dependencies></project>
(5)为子模块添加名为application的yml配置文件(注:yml是官方推荐的配置文件格式,最好使用yml文件而不是properties文件)

效果图:

(6)修改application.yml文件配置
server:port: 3344
spring:application:#注册进Eureka的微服务名称name: cloud-config-centercloud:config:server:git:#仓库路径地址uri: https://gitee.com/用户名/springcloud-config.git#搜索目录search-paths:- springcloud-config#跳过ssl验证skip-ssl-validation: true#如果是github的就填github的,如果仓库是公开的,这里不用填username: 这里填你gitee的账号#如果是github的就填github的,如果仓库是公开的,这里不用填password: 这里填你gitee的密码#读取分支label: mastereureka:client:#表示是否将自己注册进Eureka Server里,默认为trueregister-with-eureka: falseservice-url:defaultZone: http://eureka7001.com:7001/eureka/

search-paths表示搜索指定路径下的指定项目路径,lable指定的是读取的分支

效果图:

(7)为cloud-config-center-3344子模块新建一个主启动类,类名输入com.ken.springcloud.ConfigCenterMain3344,然后创建即可

效果图:

(8)编写ConfigCenterMain3344主启动类
package com.ken.springcloud;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;@SpringBootApplication
//开启配置中心
@EnableConfigServer
public class ConfigCenterMain3344 {public static void main(String[] args) {SpringApplication.run(ConfigCenterMain3344.class, args);}}

5、修改windows下的hosts文件,增加映射

进入C:\Windows\System32\drivers\etc目录,修改hosts文件,增加config-3344.com的映射

示例:

6、分别启动eureka-server7001、cloud-config-center-3344服务

效果图:

7、在浏览器的地址栏里输入http://config-3344.com:3344/master/config-dev.yml然后回车调用

调用成功后会返回配置内容,这证明config服务成功从gitee上读取配置内容

效果图:

其他:

1、不指定分支的话,会默认读取application.yml里的cloud.config.server.label里的分支

例如我在浏览器里请求http://config-3344.com:3344/config-dev.yml地址,返回的是master里的config-dev.yml的内容

2、请求不存在的配置文件,返回的是{}

例:

3、变换路径可以使配置内容以JSON形式返回,例如我在浏览器请求http://config-3344.com:3344/config/dev/master地址,返回的是JSON形式的配置内容

具体路径的变换形式可以看官方文档:

https://cloud.spring.io/spring-cloud-static/spring-cloud-config/2.2.1.RELEASE/reference/html/

其中label表示分支(branch)、application表示服务名,profiles表示环境(dev/test/prod),拿http://config-3344.com:3344/config/dev/master地址来解释就是master是分支,config-3344.com是服务名,dev是环境,

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

相关文章:

  • 鸿蒙5:组件状态共享
  • STM32-第一节-新建工程,GPIO,点亮LED,蜂鸣器
  • 七天学会SpringCloud分布式微服务——05——OpenFeign
  • Hadoop WordCount 程序实现与执行指南
  • 大数据(3)-Hive
  • 【时时三省】vectorcast使用教程
  • 烘焙工业4.0:自动化升级与制造执行MES系统的深度赋能
  • 【软考中级·软件评测师】下午题·面向对象测试之架构考点全析:分层、分布式、微内核与事件驱动
  • 【原创】【5】【视频二创工具发布】基于视觉模型+FFmpeg+MoviePy实现短视频自动化二次编辑+多赛道
  • 国产车哪款有远程代驾功能?远程代驾+自动驾驶
  • 【Wireshark】高级过滤技巧精讲
  • APP 内存测试--Android Profiler实操(入门版)
  • Unity编辑器扩展之扫描项目中所有图片资源,并找出引用这些图片的预制体及其引用路径,最终导出为CSV报告
  • Monorepo+Pnpm+Turborepo
  • Windows 安装 nodejs npm
  • 网络拓扑图绘制全流程:从架构解析到工具实战
  • Jenkins Pipeline 实战指南
  • Java基础(六):数组全面解析
  • python+uniapp基于微信小程序的生鲜订购系统nodejs+java
  • Java 图书管理系统
  • 在拉卡拉分账功能中实现实时更新,需结合异步回调通知和数据库事务来确保数据一致性。以下是具体实现方案
  • 【Linux系统部分】在Linux命令行中写一个简单的shell外壳
  • 网络安全2023—新安全新发展
  • HarmonyOS NEXT仓颉开发语言实战案例:电影App
  • 【AI时代速通QT】第四节:Windows下Qt Creator调试指南
  • Oracle 进阶语法实战:从多维分析到数据清洗的深度应用​(第四课)
  • ChatGPT、DeepSeek等大语言模型助力高效办公、论文与项目撰写、数据分析、机器学习与深度学习建模等科研应用
  • SQL参数化查询:防注入与计划缓存的双重优势
  • 高性能MySQL集群:架构设计与优化实战指南
  • 银河麒麟系统上利用WPS的SDK进行WORD的二次开发