手记

spring-cloud入门(三):spring-cloud-config(配置中心)

前言

在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件:spring-cloud-config ,它支持配置服务放在配置服务的内存中(即本地),也支持放在远程Git仓库中。

本节主要演示怎么用Git仓库作为配置源。

开源地址:https://github.com/bigbeef
个人博客:http://blog.cppba.com

创建配置项目

在github中创建一个项目,专门用来保存我们所有项目的配置文件,项目是我的项目结构

配置项目地址:https://github.com/bigbeef/cppba-config

1

eureka-server.properties

eureka.client.register-with-eureka=falseeureka.client.fetch-registry=falsespring.application.name=eureka-server
server.port=18761eureka.instance.hostname=peer1
eureka.client.serviceUrl.defaultZone=http://peer1:18761/eureka/

创建spring-cloud-config-server项目

项目结构如图:


2

pom.xml核心代码

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

SpringCloudConfigServerApplication.java

package com.cppba;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.config.server.EnableConfigServer;@SpringBootApplication@EnableConfigServerpublic class SpringCloudConfigServerApplication {    public static void main(String[] args) {
        SpringApplication.run(SpringCloudConfigServerApplication.class, args);
    }
}

application.properties

这个根据自己实际的git项目修改配置

server.port=8888spring.application.name=config-server

spring.cloud.config.server.git.uri=https://github.com/bigbeef/cppba-configspring.cloud.config.label=master# spring.cloud.config.server.git.username=# spring.cloud.config.server.git.password=spring.cloud.config.server.git.searchPaths=\
  cppba-spring-cloud/*,\
  cppba-spring-cloud/eureka-client/*

spring.cloud.config.server.git.uri:配置git仓库地址
spring.cloud.config.server.git.searchPaths:配置仓库路径,以逗号隔开
spring.cloud.config.label:配置仓库的分支
spring.cloud.config.server.git.username:访问git仓库的用户名
spring.cloud.config.server.git.password:访问git仓库的用户密码

启动项目

访问地址:http://127.0.0.1:8888

http请求地址和资源文件映射如下:
/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}-{profile}.properties
/{label}/{application}-{profile}.properties

根据我们自己的配置,我们可以这样访问:
http://127.0.0.1:8888/eureka-server/default/master

application -> eureka-server (应用名)
profile     -> default       (启用的配置,通常是后缀,下面解释)
label       -> master        (分支)

访问到的结果就是:


3

profile比较重要,可以理解成读取哪些配置文件,假如我不止一个配置文件,可能会有:

eureka-server.properties(这个是通用配置文件,默认都会加载),
eureka-server-mysql.properties,
eureka-server-oracle.properties,
eureka-server-jpa.properties,
eureka-server-mysql.properties......

我们可能会选择性的加载其中的部分properties配置文件,那我们可以这样写:
http://127.0.0.1:8888/eureka-server/default,mysql,jpa/master

到此,我们的spring-cloud-config-server就简单搭起来,后面的章节我会教大家怎么在项目中读取配置



作者:大黄蜂coder
链接:https://www.jianshu.com/p/6d51157d22ed


0人推荐
随时随地看视频
慕课网APP