开发者学堂课程【全面讲解 Spring Cloud Alibaba 技术栈:微服务解决方案】学习笔记,与课程紧密联系,让用户快速学习知识。
课程地址:https://developer.aliyun.com/learning/course/683/detail/11857
微服务解决方案
内容介绍:
一、微服务架构的常见问题
二、微服务架构的常见解决思路
三、微服务架构的常见解决方案
一、微服务架构的常见问题
1.这么多小服务,如何管理他们?
加入用于服务治理的注册中心,来进行自动化管理[发现剔除]
2.这么多小服务,他们之间如何通讯?
采用 restful rpc 风格的 HTTP 协议进行通讯( restful rpc )
3.这么多小服务,客户端怎么访问他们?
加入网关机制
4.这么多小服务,一旦出现问题了,应该如何自处理?
进行服务的容错(容错包括三个方面)
5.这么多小服务,一旦出现问题了,应该如何排错?
站在程序员角度,加入一个链路追踪的机制
对于上面的问题,是任何一个微服务设计者都不能绕过去的,因此大部分的微服务产品都针对每一个问题提供了相应的组件来解决它们
二、微服务架构的常见解决思路
(图片从概念上囊括了所有的问题以及解决思路)
1.图片的中间部分,就是微服务,图片中列举了很多的微服务,具体是在前面加设一层网关,用户通过网关来调用各个微服务。
2.图片的左边部分,包括服务配置与治理,
(1)服务治理是利用注册中心,把我们所有的服务都在里面注册,通过注册中心实现注册、发现以及服务剔除。
(2)服务配置是将所有服务的配置进行管理,放在一个单独的组件上就是配置管理。
3.图片的右半部分,包括链路追踪与服务监控
(1)链路追踪,就像一个 GPS,它能跟着你的请求到达每一个微服务上,并记录下在这个调用过程中的各种各样的信息。
(2)服务监控,监控,跟我们的链路追踪有异曲同工之妙,它也是对我们的服务里的各种健康状况,做一个检查,会给报表等一些列东西(知道)
4.图片的下半部分就是消息总线,消息总线主要用于异步消息调用,可以用来发消息(了解即可,后面的课程有具体的讲解)
三、微服务架构的常见解决方案
1. ServiceComb
Apache ServiceComb,前身是华为云的微服务引擎 CSE( Cloud Service Engine )云服务,是全球首个 Apache 微服务顶级项目。它提供了一站式的微服务开源解决方案,致力于帮助企业、用户和开发者将企业应用轻松微服务化上云,并实现对微服务应用的高效运维管理。
2.SpringCloud
SpringCloud 是一系列框架的集合。它利用 SpringBoot 的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用 SpringBoot 的开发风格做到一键启动和部署。
SpringCloud 并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过 SpringBoot 风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。
3.SpringCloud Alibaba
Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 SpringCloud 编程模型轻松使用这些组件来开发分布式应用服务。依托 Spring Cloud Alibaba,您只需要添加一些注解和少量配置,就可以将 SpringCloud 应用接入阿里微服务解决方案,通过阿里中间件来讯速搭建分布式应用系统。
4.主要功能
(1)服务限流降级:默认支持 WebServlet、WebFlux,OpenFeign、RestTemplate、Spring Cloud Gateway
Zuul,Dubbo 和 RocketMQ 限流降级功能的接入,可以在运行时通过控制台实时修改限流降级规则,还支持查看限流降级 Metrics 监控。
(2)服务注册与发现:适配 SpringCloud 服务注册与发现标准,默认集成了 Ribbon 的支持。
分布式配置管理:支持分布式系统中的外部化配置,配置更改时自动刷新。
(3)消息驱动能力:基于 SpringCloudStream 为微服务应用构建消息驱动能力。
(4)分布式事务:使用@GlobalTransactional 注解,高效并且对业务零侵入地解决分布式事务问题。
(5)阿里云对象存储:阿里云提供的海量、安全、低成本、高可靠的云存储服务。支持在任何应用、任何时间、任何地点存储和访问任意类型的数据。
(6)分布式任务调度:提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。同时提供分
布式的任务执行模型,如网格任务。网格任务支持海量子任务均匀分配到所有 Worker( schedulerx-client ) 上执行。
(7)阿里云短信服务:零盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业讯速搭建客户触达通道。
5.组件
(1)Sentinel: 把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。
(2)Nacos: 一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。
(3)RocketMQ: 一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。
(4)Dubbo: Apache Dubbo 是一款高性能 Java RPC 框架。
(5)Seata: 阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。
(6)Alibaba Cloud ACM: 一款在分布式架构环境中对应用配置进行集中管理和推送的应用配置中心产品。
(7)Alibaba Cloud OSS: 阿里云对象存储服务( Object Storage Service,简称 OSS ),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。
(8)Alibaba Cloud SchedulerX: 阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、高可靠、
高可用的定时(基于 Cron 表达式)任务调度服务。
(9)Alibaba Cloud SMS: 覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。