APP下载

微服务之架构技术选型与设计

消息来源:baojiabao.com 作者: 发布时间:2024-05-19

报价宝综合消息微服务之架构技术选型与设计

本文主要介绍了架构技术选型与设计-微服务选型,Spring cloud 实现采用的技术,希望对您的学习有所帮助。

架构技术选型与设计-DUBBODubbo,是阿里巴巴服务化治理的核心框架,并被广泛应用于阿里巴巴集团的各成员站点(阿里巴巴现在使用架构为HSF)。 于2012-10-24最后版本2.5.3成为最后一版本,由当当接手维护,命名为dubbox;2017年突然继续dubbo进行维护,最后更新版本时间为 2017-10-11 22:21

Dubbo 核心部件:Provider: 暴露服务的提供方。Consumer:呼叫远端服务的服务消费方。Registry: 服务注册中心和发现中心。Monitor: 统计服务和呼叫次数,呼叫时间监控中心。(dubbo的控制台页面中可以显示)Container:服务执行的容器。Dubbo服务丛集-丛集容错模式

架构技术选型与设计-微服务选型

架构技术选型与设计-DUBBO

架构技术选型与设计-DUBBO

架构技术选型与设计-微服务选型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 无疑是最佳选择。

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个子专案,里面都包含一个或者多个第三方的元件或者框架!

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 情况

Spring cloud 规划设计

Spring cloud 配置中心

Spring cloud 注册中心

Spring cloud 闸道器: 服务路由、安全认证、会话共享、客户端负载均衡、统一异常处理、跨域请求

Spring cloud 断路由

关注我+开启私信

回复关键词 【架构】可以免费获取大型互联网架构资料+社群交流+大牛解答

比你优秀的人都领了,信则有不信则无,相信相信的力量

2019-11-10 08:51:00

相关文章