谷粒商城学习笔记-20-分布式组件-SpringCloud Alibaba简介

文章目录

本节主要介绍了项目选用的微服务SpringCloud组件。

一,微服务组件来源介绍

组件主要来自两个机构,一个是Spring官方,一个是阿里巴巴开源的组件。之所以使用阿里开源的组件,主要生Spring官方对某些组件停止维护,而阿里开源组件中有青出于蓝而胜于蓝的组件可供选用。

Spring官方已经宣布停止维护的Spring Cloud组件包括以下几项:

  1. Spring Cloud Sleuth

    • 分布式追踪系统,用于收集和分析微服务架构下的请求链路数据。Sleuth的核心功能已经转移到Micrometer Tracing项目。
  2. Spring Cloud Cloudfoundry

    • 针对Cloudfoundry PaaS平台的集成组件,已经停止维护。
  3. Ribbon

    • 客户端负载均衡器,用于实现客户端的负载均衡调用。Spring官方表示Ribbon进入维护模式,意味着只有关键的bug修复和安全问题会被解决,没有新的功能开发。
  4. Hystrix

    • 断路器组件,用于实现服务间的容错和隔离,防止级联故障。Hystrix也停止了维护,Spring官方推荐使用Resilience4j作为替代。
  5. Spring Cloud Config

    • 虽然不完全停止维护,但Spring Cloud Config的使用被标记为"不推荐",建议使用如Apollo或Nacos等替代方案。
  6. Eureka

    • 服务发现与注册组件,虽然Eureka本身并没有完全停止维护,但在某些情况下,Spring官方推荐使用其他服务发现组件,如Consul或Zookeeper,以及Spring Cloud Netflix的替代品。

对这些停止维护或者更新组件,建议考虑使用替代方案或更新的组件以获得更好的支持和功能。

二,SpringCloud Alibaba简介

1,简介

Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

依托Spring Cloud Alibaba,只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。

2,SpringCloud 的几大痛点

  • SpringCloud 部分组件停止维护和更新,给开发带来不便;
  • SpringCloud 部分环境搭建复杂,没有完善的可视化界面,我们需要大量的二次开发和定制
  • SpringCloud 配置复杂,难以上手,部分配置差别难以区分和合理应用

3,SpringCloud Alibaba 的优势,

阿里使用过的组件经历了考验,性能强悍,设计合理,现在开源出来大家用成套的产品搭配完善的可视化界面给开发运维带来极大的便利搭建简单,学习曲线低。

三,谷粒商城项目选型列表

1,注册中心-Nacos

SpringCloud Alibaba - Nacos:注册中心(服务发现/注册)

2,配置中心-Nacos

SpringCloud Alibaba - Nacos:配置中心(动态配置管理)

3,负载均衡-Ribbon

SpringCloud - Ribbon:负载均衡

4,远程调用-OpenFeign

SpringCloud - OpenFeign:声明式 HTTP 客户端(调用远程服务)

5,限流降级熔断-Sentinel

SpringCloud Alibaba - Sentinel:服务容错(限流、降级、熔断)

6,网关-Gateway

SpringCloud - Gateway:API 网关(webflux 编程模式)

7,链路追踪-Sleuth

SpringCloud - Sleuth:调用链监控

8,分布式事务-Seata

SpringCloud Alibaba - Seata:原 Fescar,即分布式事务解决方案

相关推荐
独行soc11 分钟前
2025年渗透测试面试题总结-百度面经(题目+回答)
运维·开发语言·经验分享·学习·面试·渗透测试·php
海棠蚀omo20 分钟前
C++笔记-红黑树
开发语言·c++·笔记
ysy16480672391 小时前
03算法学习_977、有序数组的平方
学习·算法
掘金-我是哪吒1 小时前
分布式微服务系统架构第129集:redis安装部署文档
redis·分布式·微服务·架构·系统架构
FAREWELL000751 小时前
Unity学习总结篇(1)关于各种坐标系
学习·unity·c#·游戏引擎
龙湾开发1 小时前
计算机图形学编程(使用OpenGL和C++)(第2版)学习笔记 12.曲面细分
c++·笔记·学习·3d·图形渲染
霸王蟹1 小时前
React中巧妙使用异步组件Suspense优化页面性能。
前端·笔记·学习·react.js·前端框架
ljt27249606611 小时前
Compose笔记(二十四)--Canvas
笔记·android jetpack
jz_ddk2 小时前
[学习] RTKLib详解:rtcm2.c、rtcm3.c、rtcm3e与rtcmn.c
c语言·学习·算法
计算机毕设定制辅导-无忧学长2 小时前
RabbitMQ 消息模式实战:从简单队列到复杂路由(一)
分布式·rabbitmq·ruby