一、常见的微服务框架
(1)SpringCloud:是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。
(2)ServiceComb:是业界第一个Apache微服务顶级项目,是一个开源微服务解决方案,致力于帮助企业、用户和开发者将企业应用轻松微服务化上云,并实现对微服务应用的搞笑运维管理。其提供一站式开源微服务解决方案,融合SDK框架级、0侵入ServiceMesh场景并支持多语言。
(3)ZeroC ICE:是ZeroC公司的杰作,集成了CORBA的血统,是新一代的面向对象的分布式系统中间件。作为一种微服务架构,它基于RPC框架发展而来,具有良好的性能与分布式能力。
Spring Cloud的架构
1. Spring Cloud中的核心组件
Spring Cloud的本质是在Spring Boot的基础上,增加了一堆微服务相关的规范,并对应用上下文(Application Context)进行了功能增强。既然Spring Cloud是规范,那么就需要去实现,目前Spring Cloud规范已有Spring官方、Spring Cloud NetFlix、Spring Cloud Alibaba等实现。通过组件化的方式,Spring Cloud将这些实现整合到一起构成全家桶式的微服务技术栈。
(1)Spring Cloud Netflix组件
(2)Spring Cloud Alibaba组件
(3)Spring Cloud原生及其他组件
2. Spring Cloud的体系结构
从上图可以看出Spring Cloud各个组件相互配合,合作支持一套完整的微服务架构。