一、概述
(1)背景
微服务意味着将单体应用中的业务拆分成一个个子服务,每个服务的粒度相对较小,因此系统中出现大量的服务。由于每个服务都需要配置必要的配置信息才能运行,所以一套集中式的、动态的配置管理设施是必不可少的。Spring Cloud提供了ConfigServer来解决这个问题,我们每一个微服务自己都带着application.yml,上百个配置文件的管理……接下来你会疯的。
(2)Config是什么?
SpringCloud Config为微服务架构中的微服务提供了集中化的外部配置支持,配置服务器为各个不同微服务应用的所有环境提供了一个中心化的外部配置。
SpringCloud Config分为服务端和客户端:
服务端:也被称为分布式配置中心,它是一个独立的微服务应用,用来连接配置服务器并为客户端提供获取配置信息,加密/解密信息等访问接口。
客户端:通过指定的配置中心来管理应用资源,以及与业务相关的配置内容,并在启动的时候从配置中心获取和加载配置信息,配置服务器默认采用git来存储配置信息,这样有助于对环境配置进行版本管理,并且可以用过git客户端工具来方便的管理和访问配置内容。
本项目地址:https://github.com/Simple-Coder/microservice-demo-study
二、SpringCloud Config服务端配置
(1)github新建仓库,名为:microservice-config
我这里已经建好地址:https://github.com/Simple-Coder/microservice-config
①根据ssh地址:git@github.com:Simple-Coder/microservice-config.git,在本地硬盘目录新建git仓库并clone
②在刚刚创建的本地仓库中新疆:application.yml,添加如下配置并通过git客户端推送到github
spring:
profiles:
active:
- dev
---
spring:
profiles: dev #开发环境
application: microservice-config-dev
---
spring:
profiles: test #测试环境
application:
name: microservice-config-test
#保存为utf-8格式
③新建Module模块:microservice-config3344(配置中心模块),Maven工程结构图如下:
④microservice-config模块:pom依赖、application.yml、启动类
<dependencies> <!--config server--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-server</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> </dependency> </dependencies>
server:
port: 3344
spring:
application:
name: microservice-config
cloud:
config:
server:
git:
uri: git@github.com:Simple-Coder/microservice-config.git #github上的仓库地址
@SpringBootApplication
@EnableConfigServer
public class ConfigApplication {
public static void main(String[] args) {
SpringApplication.run(Application.class);
}
}
⑤本地hosts文件添加映射:C:WindowsSystem32driversetchosts
⑥启动microservice-config测试
(1)浏览器访问:http://config3344.com:3344/application-dev.yml,出现以下界面说明服务端配置成功!
(2)浏览器访问:http://config3344.com:3344/application-test.yml
(3)浏览器访问不存在的配置:http://config3344.com:3344/application-xx.yml
注:配置读取规则!
至此,成功实现了用SpringCloud Config通过github获取配置信息
三、SpringCloud Config客户端配置
(1)新建microservice-config-client3355模块,Maven模块图如下:
(2)microservice-config-client3355添加:pom、bootstrap.yml、application.yml
<dependencies> <!--spring cloud config客户端--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-context</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-eureka</artifactId> </dependency> </dependencies>
spring:
cloud:
config:
name: microservice-config-client #需要从github上读取的资源名称,注意没有yml名称
profile: dev #本次访问的配置项
label: master
uri: http://config3344.com:3344 #本服务启动后先去找3344服务,通过SpringCloudConfig获取github的服务地址
spring:
application:
name: microservice-config-client
(3)本地hosts添加文件:C:WindowsSystem32driversetchosts
(4)依次启动:3个eureka集群、1个config server、1个config client
(5)config server自测:
http://config3344.com:3344/application-dev.yml和http://config3344.com:3344/application-test.yml
(6)根据config client的bootstrap.yml指定生效的profile如下:
(7)测试controller和控制台打印效果:
@RestController
public class TestController {
@Value("${spring.application.name}")
private String applicationname;
@Value("${eureka.client.service-url.defaultZone}")
private String eurekaServsers;
@Value("${server.port}")
private String port;
@RequestMapping("/config")
public String getConfig()
{
System.out.println("applicationName:"+applicationname);
System.out.println("eurekaServers:"+eurekaServsers);
System.out.println("port:"+port);
return "applicationName:"+applicationname+"
"+"eurekaServers:"+eurekaServsers+"
"+"port:"+" "+port;
}
}
(8)浏览器访问:http://configclient.com:5001/config
(9)修改bootstrap.yml,再次查看控制台及访问路径:http://configclient.com:5002/config
至此,config 客户端的搭建完成!
四、SpringCloud Config配置实战
目前情况:
①Config服务端配置OK且测试通过,我们可以和config+github进行配置修改并获得内容
②此时:做一个eureka服务+一个provider访问的微服务,将两个微服务的配置统一由github实现统一配置分布式管理,完成多环境的变更
(1)Git配置文件本地配置
①本地git仓库新建:microservice-config-eureka.yml,添加如下配置:
spring:
profiles:
active:
- dev
---
server:
port: 8001
spring:
profiles: dev
application:
name: microservice-config-eureka
eureka:
instance:
hostname: eureka8001
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://eureka8001:8001/eureka/
---
server:
port: 8001
spring:
profiles: test
application:
name: microservice-config-eureka
eureka:
instance:
hostname: eureka8001
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://eureka8001:8001/eureka/
②本地git仓库新建:microservice-config-provider.yml,添加如下配置:
(2)Config版的eureka服务端
①启动config server自测:http://config3344.com:3344/microservice-config-eureka-test.yml
②microservice-config-eureka8001模块:bootstrap.yml添加如下配置
③启动类:application.java
@SpringBootApplication
@Slf4j
@EnableEurekaServer
public class Application {
public static void main(String[] args) {
try {
SpringApplication.run(ApplicationBoot.class, args);
} catch (Throwable t) {
log.error("启动失败", t);
throw t;
}
}
}
④测试,查看控制台
(2)Config版的provider微服务
①config server自测:http://config3344.com:3344/microservice-config-provider/test
②新建模块:microservice-config-provider9001,Maven工程结构图如下:
③该模块添加:pom依赖、bootstrap.yml、application.yml
<dependencies> <!--spring cloud config客户端--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-eureka</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>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <version>${spring-boot.version}</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>javax.el</groupId> <artifactId>javax.el-api</artifactId> <version>3.0.0</version> <scope>test</scope> </dependency> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <scope>runtime</scope> </dependency> <!--模块间引用--> <dependency> <groupId>com.microservice</groupId> <artifactId>microservice-inf</artifactId> <version>1.0.0</version> </dependency> <dependency> <groupId>com.microservice</groupId> <artifactId>microservice-service-impl</artifactId> <version>1.0.0</version> </dependency> <dependency> <groupId>com.microservice</groupId> <artifactId>miscroservice-common</artifactId> <version>1.0.0</version> </dependency> </dependencies>
spring:
cloud:
config:
name: microservice-config-provider #需要从github上读取的资源名称,注意没有yml名称
profile: test #本次访问的配置项
label: master
uri: http://config3344.com:3344 #本服务启动后先去找3344服务,通过SpringCloudConfig获取github的服务地址
spring:
application:
name: microservice-provider
④依次启动:config-server、config-eureka、config-provider模块
⑤浏览器访问:http://localhost:9001/provider/all,出现以下结果:生效的profile为test
⑥将profile修改为dev,开发环境再次测试,访问:http://localhost:9001/provider/all
至此、分布式配置中心的客户端和服务器也已经测试完成!
五、总结
至此、SpringCloud的基本组件:Eureka、Ribbon、Feign、Hystrix、Zuul、Config已经了解了,接下来i就是一些进阶的,比如:
①SpringCloud Stream:数据流开发包
②SpringCloud Turbine:聚合服务器发送事件流数据的一个工具,用来监控集群下hystrix的metrics情况
③SpringCloud Task:提供云端计划任务管理、任务调度
④SpringCloud Sleuth:日志收集工具包实现了一种分布式追踪解决方案,封装了Dapper和log-based追踪以及Zipkin和HTrace操作。
⑤SpringCloud Security:基于spring security的安全工具包,为应用程序添加安全控制
以及其他方面的学习,例如:
①服务部署:Kubernetes、OpenStack
②全链路追踪:Zipkin,brave
③服务监控:zabbix
④SpringCloud CLI:基于Spring Boot CLI,可以以命令行的方式快速建立云组件
⑤全局控制:选举leader、全局锁、全局唯一id
⑥安全鉴权:Oauth2、openId connect
⑦自动化构建与部署:gitlab+jenkins+docker