Bootstrap

Spring Cloud第二代

原文链接:http://springcloud.cn/view/415

摘要: 随着Eureka不再维护,Hystrix不再开发新功能,进入维护状态。以及最近中国开源出现一些大事,预测一下2019年未来Spring Cloud生态圈中的第二代组件的组合,仅代表个人看法

1. Spring Cloud第一代

Spring Cloud自从推出之后,给大家的感觉就是Spring Cloud做它最擅长的事,也就是高度抽象和封装,强强联手整合最优东西为我所用,比如Netflix开源的Eureka,Hystrix,Ribbon等。而且提供多种技术选型,态度中立而选最优。8天前也就是2018年11月19号左右,Netflix的开源项目Hystrix宣布状态,不再开发新功能,处于维护状态。引发朋友圈的一些思考。

 

虽然Eureka,Hystrix等不再继续开发或维护,但是目前来说不影响使用,不管怎么说感谢开源,向Netflix公司的开源致敬。

随着Spring Cloud生态圈的发展与成长,Spring Cloud陆续推出了自己的一些组件,挑选主要组件说明如下表所示:

组件来源说明
Spring-cloud-openfeign基于Feign的升级服务之间调用的必备组件
spring-cloud-zuul来源于Netflix Zuul目前还在继续维护,但是已经有自己的Spring Cloud Gateway,不久将来逐渐淘汰
spring-cloud-eureka集成于Netflix Eureka目前还在跟随Spring Cloud版本升级维护,最终也会被替代
spring-cloud-config自研功能不足,国内使用其它配置中心替代,比如携程的Apollo
全链路监控(sleuth+zikpin或pinpont)sleuth自研,其它第三方国内目前使用最多的是skywaling等上生产
spring-cloud-ribbon来源于Netflix集成ribbon目前还在跟随Spring Cloud版本维护中,目前孵化未来替代品spring-cloud-lb
Spring-cloud-hystrix来源于Netflix集成目前还在跟随Spring Cloud版本维护中目前已经孵化spring-cloud-r4j

2. Spring Cloud 第二代

Spring Cloud第一代和第二代的组件组合汇总,如下表所示。

 Spring Cloud第一代Spring Cloud第二代
网关Spring Cloud ZuulSpring Cloud Gateway
注册中心eureka(不再更新),Consul,ZK阿里Nacos,拍拍贷radar等可选
配置中心spring cloud config阿里Nacos,携程Apollo,随行付Config Keeper
客户端软负载均衡Ribbonspring-cloud-loadbalancer
熔断器Hystrixspring-cloud-r4j(Resilience4J),阿里Sentinel

由于Zuul性能一般,zuul 2.x(一直跳票,虽最终开源)但是Spring Cloud官方已经推出Spring Cloud gateway,Spring Cloud中国社区很久之前已经证实,Spring Cloud将不会集成zuul 2.x,也就是说在不就未来Zuul将从Spring Cloud生态圈中退出。


ribbon由于不支持webFlux的负载均衡,Spring Cloud官方很早就在孵化器项目中孵化spring-cloud-loadbalancer,目前已经将代码合并到spring-cloud-common中,预计在Spring Cloud G版可以使用,预计2018年12月底realese。


至于Hystrix,Netflix在2018年11月19号左右,Netflix的开源项目Hystrix宣布状态,不再开发新功能,处于维护状态,其实在之前Spring Cloud官方就在孵化spring-cloud-r4j.

3.开源项目的链接

本文所提到的开源项目链接汇总如下所示:

https://github.com/alibaba/Sentinel

https://github.com/spring-cloud-incubator/spring-cloud-r4j

阿里Nacos-https://github.com/alibaba/nacos

随行付Config-keeper-https://github.com/sxfad/config-keeper

spring-cloud-loadbalancer

https://github.com/ctripcorp/apollo

https://github.com/apache/incubator-skywalking

;