阿里巴巴资深架构师深度解析微服务架构设计之SpringCloud+Dubbo

简介: 微服务软件架构是一个包含各种组织的系统组织,这些组件包括Web服务器,应用服务器,数据库,存储,通讯层),它们彼此或和环境存在关系。系统架构的目标是解决利益相关者的关注点。

微服务

软件架构是一个包含各种组织的系统组织,这些组件包括Web服务器,应用服务器,数据库,存储,通讯层),它们彼此或和环境存在关系。系统架构的目标是解决利益相关者的关注点。


编辑切换为居中

添加图片注释,不超过 140 字(可选)


什么是微服务架构

微服务架构优势

独立部署,由于微服务具备独立的运行进程,所以每个微服务也可以独立部署。当某个微服务发生变更时无需编译、部署整个应用。由微服务组成的应用相当于具备一系列可并行的发布流程,使得发布更加高效,同时降低对生产环境所造成的风险,最终缩短应用交付周期。

技术选型灵活微服务架构下,技术选型是去中心化的。每个团队可以根据自身服务的需求和行业发展的现状,自由选择最适合的技术栈。由于每个微服务相对简单,当需要对技术栈进行升级时所面临的风险较低,甚至完全重构一个微服务也是可行的。

容错:当某个组建发生故障时,在单一进程的传统架构下,故障很有可能在进程内扩散,形成应用全局性的不可用。在微服务架构下,故障会被隔离在单个服务中。若设计良好,其他服务可通过重试、平稳退化等机制实现应用层面的容错。

扩展:单块架构应用也可以实现横向扩展,就是将整个应用完整的复制到不同的节点。当应用的不同组件在扩展需求上存在差异时,微服务架构便体现出其灵活性,因为每个服务可以根据实际需求独立进行扩展。

高并发

1、应用缓存

2、HTTP缓存

3、多级缓存

4、池化

5、步并发

6、扩容

7、队列

Dubbo

1、服务集群-集群容错模式

2、服务提供者集群与负载均衡

3、架构高并发高可用选型技术

4、部署图

Spring Cloud 19个技术

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

互联网微服务架构设计总结

共五大模块74个知识点解析互联网微服务架构:高并发、高可用、Dubbo、SpringCloud、Docker



编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发-应用缓存


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发- HTTP缓存


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发- 多级缓存(分布式缓存)


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发-扩容


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发-扩容分布式数据库


编辑切换为居中

添加图片注释,不超过 140 字(可选)



编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发-队列应用场景


编辑切换为居中

添加图片注释,不超过 140 字(可选)



编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发小结——应用缓存、HTTP缓存、多级缓存、池化、异步并发、扩容、队列

高可用


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高可用-负载均衡


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高可用-反向代理


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高可用-隔离术


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高可用小结——负载均衡与反向代理、隔离、限流、降级、超时与重试、回滚、压力测试与应急预案

Dubbo

详细介绍


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Dubbo服务集群-集群容错模式


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Dubbo 服务提供者集群与负载均衡


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Dubbo架构高并发高可用选型技术


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Dubbo大体部署图


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Spring Cloud

Spring Cloud和dubbo比较-背景


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Spring Cloud微服务架构图


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Spring Cloud大致部署图


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Spring cloud、Docker署的支持


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Spring Cloud和Dubbo比较-对比


编辑切换为居中

添加图片注释,不超过 140 字(可选)


技术架构建议

1、Dubbo,是阿里巴巴服务化治理的核心框架,并被广泛应用于阿里巴巴集团的各成员站点(阿里巴巴现在使用架构为HSF)。 于2012-10-24最后版本2.5.3成为最后一版本,已经成为过去,也是过去的王者

2、Spring Cloud,从命名我们就可以知道,它是Spring Source的产物,Spring社区的强大背书可以说是Java企业界最有影响力的组织了,除了Spring Source之外,还有Pivotal和Netfix是其强大的后盾与技术输出,是现今微服务的王者

3、Saas的部署最好在Docker环境下部署,Spring Cloud无缝衔接

4、 Spring Cloud 和 Dubbo技术在服务治理上Spring Cloud 显然优越于Dubbo,配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁,领导选举,分布式会话,群集状态,一直是dubbo架构部署运行后最为头疼的事情, Spring Cloud 一一自带组件解决了这些问题。

5、针对当前项目来说,团队项目采用spring boot, 学习成本成本很少

6、 Spring Cloud依托于spring boot,天然可以部署在Docker环境下,天生就是为高可用而设计的,维护成本比dubbo低很多


阿里巴巴微服务:SpringCloud+SpringBoot+Docker+Dubbo


架构设计


编辑切换为居中

添加图片注释,不超过 140 字(可选)


微服务架构


编辑切换为居中

添加图片注释,不超过 140 字(可选)


Docker环境搭建


编辑切换为居中

添加图片注释,不超过 140 字(可选)


SpringBoot


编辑切换为居中

添加图片注释,不超过 140 字(可选)


使用Dubbox+Spring Boot搭建微服务架构


编辑切换为居中

添加图片注释,不超过 140 字(可选)


基于Redis+ActiveMQ实现高并发访问


编辑切换为居中

添加图片注释,不超过 140 字(可选)


分布式下的第三方接入


编辑切换为居中

添加图片注释,不超过 140 字(可选)


高并发测试


编辑切换为居中

添加图片注释,不超过 140 字(可选)


本文就是愿天堂没有BUG给大家分享的内容,大家有收获的话可以分享下,想学习更多的话可以到微信公众号里找我,我等你哦。

相关文章
|
5月前
|
算法 Java 微服务
【SpringCloud(1)】初识微服务架构:创建一个简单的微服务;java与Spring与微服务;初入RestTemplate
微服务架构是What?? 微服务架构是一种架构模式,它提出将单一应用程序划分为一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。 每个服务允许在其独立的进程中,服务于服务间采用轻量级的通信机制互相协作(通常是Http协议的RESTful API或RPC协议)。 每个服务都围绕着具体业务进行构建,并且能够被独立的部署到生产环境、类生产环境等。另外应当尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据上下文,选择合适的语言、工具对其进行构建
611 126
|
5月前
|
负载均衡 算法 Java
【SpringCloud(2)】微服务注册中心:Eureka、Zookeeper;CAP分析;服务注册与服务发现;单机/集群部署Eureka;连接注册中心
1. 什么是服务治理? SpringCloud封装了Netfix开发的Eureka模块来实现服务治理 在传统pc的远程调用框架中,管理每个服务与服务之间依赖关系比较复杂,管理比较复杂,所以需要使用服务治理,管理服务于服务之间依赖关系,可以实现服务调用、负载均衡、容错等,实现服务发现与注册
395 0
|
7月前
|
监控 Java API
Spring Boot 3.2 结合 Spring Cloud 微服务架构实操指南 现代分布式应用系统构建实战教程
Spring Boot 3.2 + Spring Cloud 2023.0 微服务架构实践摘要 本文基于Spring Boot 3.2.5和Spring Cloud 2023.0.1最新稳定版本,演示现代微服务架构的构建过程。主要内容包括: 技术栈选择:采用Spring Cloud Netflix Eureka 4.1.0作为服务注册中心,Resilience4j 2.1.0替代Hystrix实现熔断机制,配合OpenFeign和Gateway等组件。 核心实操步骤: 搭建Eureka注册中心服务 构建商品
1207 3
|
5月前
|
Cloud Native Serverless API
微服务架构实战指南:从单体应用到云原生的蜕变之路
🌟蒋星熠Jaxonic,代码为舟的星际旅人。深耕微服务架构,擅以DDD拆分服务、构建高可用通信与治理体系。分享从单体到云原生的实战经验,探索技术演进的无限可能。
微服务架构实战指南:从单体应用到云原生的蜕变之路
|
5月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
6月前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
415 1
|
6月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
814 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
6月前
|
Kubernetes Java 微服务
Spring Cloud 微服务架构技术解析与实践指南
本文档全面介绍 Spring Cloud 微服务架构的核心组件、设计理念和实现方案。作为构建分布式系统的综合工具箱,Spring Cloud 为微服务架构提供了服务发现、配置管理、负载均衡、熔断器等关键功能的标准化实现。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
614 0

推荐镜像

更多
  • DNS