一. Dubbo
Dubbo, 是阿里巴巴服务化治理的核心框架, 并被广泛应用于阿里巴巴集团的各成员站点(阿里巴巴现在使用架构为 HSF). 于 2012-10-24 最后版本 2.5.3 成为最后一版本, 由当当接手维护, 命名为 dubbox;2017 年突然继续 dubbo 进行维护.
Dubbo 核心部件:
Provider: 暴露服务的提供方.
Consumer: 调用远程服务的服务消费方.
Registry: 服务注册中心和发现中心.
Monitor: 统计服务和调用次数, 调用时间监控中心.(dubbo 的控制台页面中可以显示)
Container: 服务运行的容器.
1.1 Dubbo 服务集群 - 集群容错模式
架构技术选型与设计 - 微服务选型
架构技术选型与设计 - DUBBO
架构技术选型与设计 - DUBBO
二. Spring Cloud
Spring Cloud, 从命名我们就可以知道, 它是 Spring Source 的产物, Spring 社区的强大背书可以说是 Java 企业界最有影响力的组织了, 除了 Spring Source 之外, 还有 Pivotal 和 Netfix 是其强大的后盾与技术输出. 其中 Netflix 开源的整套微服务架构套件是 Spring Cloud 的核心.
如果拿 Dubbo 与 Netflix 套件做对比, 前者在国内影响力较大, 后者在国外影响力较大, 在背景上可以打个平手; 但是若要与 Spring Cloud 做对比, 由于 Spring Source 的加入, 在背书上, Spring Cloud 略胜一筹, 但是在高并发上 dubbo 曾经在阿里的运营中实际承载过过亿用户同时在线的, 而 Netflix 并没有实际的上线应用中体现过.
Spring Cloud 下面有 19 个子项目 (可能还会新增) 分别覆盖了微服务架构下的方方面面, 服务治理只是其中的一个方面, 一定程度来说, Dubbo 只是 Spring Cloud Netflix 中的一个子集. 但是在选择框架上, 方案完整度恰恰是一个需要重点关注的内容, 当然从高可用和高并发一起考虑, Spring Cloud 无疑是最佳选择.
2.1 Spring Cloud 工具框架
1,Spring Cloud Config 配置中心, 利用 Git 集中管理程序的配置.
2,Spring Cloud Netflix 集成众多 Netflix 的开源软件
3,Spring Cloud Bus 消息总线, 利用分布式消息将服务和服务实例连接在一起, 用于在一个集群中传播状态的变化
4,Spring Cloud for Cloud Foundry 利用 Pivotal Cloudfoundry 集成你的应用程序
5,Spring Cloud Cloud Foundry Service Broker 为建立管理云托管服务的服务代理提供了一个起点.
6,Spring Cloud Cluster 基于 Zookeeper, Redis, Hazelcast, Consul 实现的领导选举和平民状态模式的抽象和实现.
7,Spring Cloud Consul 基于 Hashicorp Consul 实现的服务发现和配置管理.
8,Spring Cloud Security 在 Zuul 代理中为 OAuth2 REST 客户端和认证头转发提供负载均衡
9,Spring Cloud Sleuth SpringCloud 应用的分布式追踪系统, 和 Zipkin,HTrace,ELK 兼容.
10,Spring Cloud Data Flow 一个云本地程序和操作模型, 组成数据微服务在一个结构化的平台上.
11,Spring Cloud Stream 基于 Redis,Rabbit,Kafka 实现的消息微服务, 简单声明模型用以在 Spring Cloud 应用中收发消息.
12,Spring Cloud Stream App Starters 基于 Spring Boot 为外部系统提供 spring 的集成
13,Spring Cloud Task 短生命周期的微服务, 为 SpringBooot 应用简单声明添加功能和非功能特性.
14,Spring Cloud Task App Starters
15,Spring Cloud Zookeeper 服务发现和配置管理基于 Apache Zookeeper.
16,Spring Cloud for Amazon web Services 快速和亚马逊网络服务集成.
17,Spring Cloud Connectors 便于 PaaS 应用在各种平台上连接到后端像数据库和消息经纪服务.
18,Spring Cloud Starters (项目已经终止并且在 Angel.SR2 后的版本和其他项目合并)
19,Spring Cloud CLI 插件用 Groovy 快速的创建 Spring Cloud 组件应用.
Spring Cloud 共集成了 19 个子项目, 里面都包含一个或者多个第三方的组件或者框架!
2.2 Spring cloud 实现采用的技术
1,spring cloud : 一个云应用工具, 为云应用开发的配置管理, 服务发现, 断路器, 智能路由, 微代理, 控制总线, 全局锁定, 决策竞选, 分布式会话和集群状态管理等操作
2,spring cloud config : 配置管理开发工具包
3, spring cloud Bus : 事件消息总线用于集群 (例如: 配置变化时间) 中传播状态变化, 与 spring cloud config 联合实现热部署
4, spring cloud Netflix Eureka : 云端负载均衡基础, 一个基于 REST 的服务, 用于定位服务, 以实现云端的负载均衡和中间层服务器的故障转移
5, spring cloud Netflix Hystrix : 容错管理工具, 旨在通过控制服务和第三方库的节点, 从而对延迟和故障提供更强大的容错能力
6 , Netflix ZUUL: 边缘服务工具, 提供动态路由, 监控, 弹性, 安全等边缘服务
7, spring cloud sleuth : 日志收集工具包, 封装 Purpose ,Zipkin 和 Trace
8, Spring Cloud Security : 安全工具包, 为应用程序添加安全控制, 主要是 OAuth2
9, spring cloud turbine : 聚合服务器发送时间流, 监控集群下 Netflix 和 metrics 情况
2.3 Spring cloud 规划设计
2.4 Spring cloud 配置中心
2.5 Spring cloud 注册中心
2.6 Spring cloud 网关
服务路由, 安全认证, 会话共享, 客户端负载均衡, 统一异常处理, 跨域请求
2.7 Spring cloud 断路由
来源: http://www.jianshu.com/p/790360d6defd