SpringCloud Config 分布式配置中心

1.为什么要使用分布式配置中心?

产生的背景:在微服务如果使用传统的方式管理配置文件,配置文件管理器非常复杂,如果生产环境配置文件,可能

需要发生改变的时候,重新打war包,重新读取配置信息在jvm内存中

2.什么是分布式配置中心?

在微服务当中使用同一个服务器管理所有服务配置文件信息,能够实现后台可管理,当服务器正在运行的时候,

如果配置文件需要发生改变,可以实现不需要重启服务器实时更改配置文件信息.

3.有哪些分布式配置中心框架? (推荐使用阿波罗和zk)

1.阿波罗携程写分布式配置中心,有图形界面可管理配置文件信息.配置文件信息存放在数据库里面.

2.SpringCloud Config没有后台可管理分布式配置中心,配置文件信息存放在版本控制器里面.

3.使用Zookeeper实现分布式配置中心,持久节点+事件通知          

4.分布式配置中心需要哪些组件?

1.Web管理系统--后台可以使用图形界面管理配置文件SpringCloud Config没有图像化管理配置文件

2.存放分布式配置文件服务器(持久存储服务器)--使用版本控制器存放配置文件信息,使用git环境

3.ConfigServer缓存配置文件服务器(临时缓存存放)

4.ConfigClient 读取ConfigServer配置文件信息.

5.搭建分布式配置中心SpringCloud Config

1.搭建git环境, 目的:持久化存储配置文件信息 采用码云

git环境上文件夹以项目进行区分

member_config会员服务配置文件

order_config订单服务配置文件

2.公司项目中环境是如何区分?

dev   开发环境

sit   测试环境

pre   预发布环境

prd   准生产环境

uat   验收环境

3.在Git环境上创建配置文件命名规范

会员服务---服务名称---member:  服务名称-环境.properties    member-dev.properties

4.默认情况下不能及时的获取实时变更的配置文件信息

SpringCloud分布式配置中心,可以采用手动刷新或者自动刷新

手动刷新--需要人工调用接口,读取最新配置文件(监控中心) 人工调用/actuator/refresh进行刷新(post请求)

自动刷新--消息总线进行实时通知---springbus


搭建步骤:

1.首先本地安装git (步骤链接如下),注册码云账号

码云账号注册

1.新建项目( 分布式配置文件  config )  

2.创建项目配置文件夹(memberconfig)  

3.创建配置文件(test-configClient-prd.properties和test-configClient-sit.properties)

(此处是配置不同环境的配置文件(测试和准生产))

4.配置文件中分别添加测试配置信息

info=prd.dengdong.com   info=prd.dengdong.com

2.搭建分布式配置中心服务端 config-server

(此时Eureka注册中心已配置已启动,注册中心访问地址  http://localhost:8000/eureka  此处事前搭好)

1.pom.xml依赖

org.springframework.cloud

spring-cloud-starter-netflix-eureka-client

org.springframework.cloud

spring-cloud-config-server


分布式配置中心依赖

2.application.properties配置文件配置

#服务端口

server.port=8888

#服务名称

spring.application.name=config-server

#eureka注册中心服务地址

eureka.client.service-url.defaultZone=http://localhost:8000/eureka

#config-server读取git环境地址  直接复制码云项目地址

spring.cloud.config.server.git.uri=https://gitee.com/zsqzhang/config.git

#码云账号密码(公开的话不用配置账号密码)

spring.cloud.config.server.git.username=******

spring.cloud.config.server.git.password=******

#读取的分支环境(之前新建的项目文件夹名称)

spring.cloud.config.server.git.search-paths=memberconfig

#读取分支类型 注意看所处码云分支类型

spring.cloud.config.label=master


3.新建启动类AppConfigServer

@SpringBootApplication

@EnableEurekaClient

@EnableConfigServer //开启config server服务器端功能

public class AppConfigServer {

public static void main(String[] args) {

SpringApplication.run(AppConfigServer.class, args);

}

}

4. 启动config-server服务端项目访问:ip+端口/码云新建配置文件名称 (即可访问当配置文件信息) ,服务端搭建成功

访问http://localhost:8888/test-configClient-sit.properties   此接口会根据码云修改,实时更新


3.搭建分布式配置中心客户端 config-client

1.添加pom.xml依赖

org.springframework.cloud

spring-cloud-config-client

org.springframework.boot

spring-boot-starter-actuator

org.springframework.cloud

spring-cloud-starter-netflix-eureka-client

org.springframework.boot

spring-boot-starter-web

2. 新建配置文件bootstrap.properties

#服务端口

server.port=8882


#服务名称 码云配置文件test-configClient-prd.properties 的项目名称 test-configClient

spring.application.name=test-configClient


#读取版本环境 码云配置文件test-configClient-prd.properties 的环境 prd

spring.cloud.config.profile=prd


#读取config-server环境  读取的配置中心名称

spring.cloud.config.discovery.service-id=config-server


#开启读取权限

spring.cloud.config.discovery.enabled=true

##eureka注册中心服务地址

eureka.client.service-url.defaultZone=http://localhost:8000/eureka

#监控中心开启所有端点

management.endpoints.web.exposure.include=*


3. 添加测试类TestController

@RestController

@RefreshScope //刷新  RefreshScope用新的环境参数重新生成Bean

public class TestController {

@Value("${info}")

private String info;

@RequestMapping("/getinfo")

public String getInfo(){

return info;

}

}

4.添加启动类APPConfigClient

@SpringBootApplication

@EnableEurekaClient

public class AppConfigClient {

public static void main(String[] args) {

SpringApplication.run(AppConfigClient.class,args);

}

}

5. 启动项目调用接口http://localhost:8882/getinfo 访问到配置信息

6. 修改码云配置文件test-configClient-prd.properties    info的内容

7. 使用postman调用监控接口,手动刷新配置,接口地址http://localhost:8882/actuator/refresh  post请求

8.再次调用http://localhost:8882/getinfo访问到配置信息

你可能感兴趣的:(SpringCloud Config 分布式配置中心)