SpringCloud系列(42)--搭建SpringCloud Config分布式配置总控中心(服务端)
搭建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-center
cloud:
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: master
eureka:
client:
#表示是否将自己注册进Eureka Server里,默认为true
register-with-eureka: false
service-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是环境,
更多推荐
所有评论(0)