这是一个持续更新的、一些关于 SpringCloud 周边的文章
比如它那不走寻常路的版本名、其各组件的功能描述等等
简介
提到 Spring Cloud,就不得不提微服务中,大名鼎鼎的 Netflix
Netflix 开源了他们家久经实战考验的一系列微服务组件,而 Spring Cloud 又对其进行了一系列封装,使之更便于使用
Spring Cloud 是在 Spring Boot 的基础上建立的
它是一个包含了诸多子项目(Spring Cloud Bus、Spring Cloud Config、Spring Cloud Netflix)的大型综合项目
其项目主页为:< http://projects.spring.io/spring-cloud/>
目前主要包括但不限于以下功能:
- 配置管理(configuration management)
- 服务发现(service discovery,也就是服务注册中心)
- 断路器(circuit breakers,也叫熔断器)
- 智能路由(intelligent routing,通常用来做 API-Gateway 实现)
- 控制总线(control bus)
- 微代理(micro-proxy)
- 全局锁(global locks)
- 领导选举(leadership election)
- 一次性令牌(one-time tokens)
- 分布式会话(distributed sessions)
- 集群状态管理(cluster state)
举个例子:比如 Spring Cloud 的子项目之一 Spring Cloud Netflix
它封装 Netflix 公司开源的一系列产品,为 SpringBoot 应用提供了自配置的 Netflix OSS 整合
比如:服务发现(Eureka)、断路器(Hystrix)、智能路由(Zuul)、客户端软负载均衡(Ribbon)等功能
版本名
目前,官网中会看到三个版本名:Angel、Brixton、Camden(注意我的用语是版本名,没说版本号)
这是由于:SpringCloud 这个包含了诸多子项目的大型综合项目,它的各子项目版本号都是各自维护的
于是为了管理子项目,避免混淆版本名与子项目版本号,才采用了命名的方式(这些<u>命名目前来看是根据英文字母顺序表的</u>)
比如最先发布的综合版本叫做 Angel,接着就是 Brixton,现在到了 Camden(相信以后会更多,26个字母,应该足够用吧)
而版本号后面的 .SR 指的是:service releases,简称 SRX(X 是一个递增数字)
通过其官网下方的 Release train contents: 表格,可以看到目前各版本名所包含的子项目
注意:关于其各版本与 Spring-Boot 版本之间的关系,也会在这里面看到
| Component | Angel.SR6 | Brixton.SR7 | Camden.SR4 | Camden.BUILD-SNAPSHOT | 
|---|---|---|---|---|
| spring-cloud-aws | 1.0.4.RELEASE | 1.1.3.RELEASE | 1.1.3.RELEASE | 1.1.4.BUILD-SNAPSHOT | 
| spring-cloud-bus | 1.0.3.RELEASE | 1.1.2.RELEASE | 1.2.1.RELEASE | 1.2.2.BUILD-SNAPSHOT | 
| spring-cloud-cli | 1.0.6.RELEASE | 1.1.6.RELEASE | 1.2.0.RC1 | 1.2.0.BUILD-SNAPSHOT | 
| spring-cloud-commons | 1.0.5.RELEASE | 1.1.3.RELEASE | 1.1.7.RELEASE | 1.1.8.BUILD-SNAPSHOT | 
| … | … | … | … | … | 
| … | … | … | … | … | 
|  | 
来源:oschina
链接:https://my.oschina.net/u/3069003/blog/3024779