当前位置: 首页 > news >正文

SpringCloud深入理解 | 生产者、消费者

在这里插入图片描述

💗wei_shuo的个人主页

💫wei_shuo的学习社区

🌐Hello World !


SpringCloud

Spring Cloud是一组用于构建分布式系统和微服务架构的开源框架和工具集合。它是在Spring生态系统的基础上构建的,旨在简化开发人员构建分布式系统和微服务应用程序的过程

在这里插入图片描述

SpringCloud生态

  • Spring Cloud NetFlix

Spring Cloud Netflix是Spring Cloud生态系统中的一个组件,它提供了与Netflix开源项目集成的功能

  • Apache Dubbo Zookeeper

Apache Dubbo是一种高性能的Java RPC(远程过程调用)框架,它提供了分布式服务治理的解决方案。Dubbo支持多种注册中心,其中包括Zookeeper

  • Spring Cloud Alibaba

Spring Cloud Alibaba提供了一套完整的解决方案,帮助开发人员构建基于阿里巴巴生态系统的微服务应用程序,实现服务注册与发现、流量控制、分布式事务等功能

SpringCloud版本

在这里插入图片描述

在这里插入图片描述

生产者(Producer)

生产者是指提供某种服务的微服务应用程序;将自己的服务注册到服务注册中心,使其他应用程序可以发现和调用它提供的服务;生产者通常会定义一组API接口,用于描述其提供的服务功能和参数;当有其他应用程序需要使用该服务时,可以通过服务注册中心找到该生产者,并使用API接口进行调用

消费者(Consumer)

消费者是指需要使用其他微服务提供的服务的应用程序;消费者通过服务注册中心查找并发现生产者的服务,并使用API接口进行调用;消费者不需要关心服务的具体实现细节,只需要知道如何调用API接口来使用服务;消费者可以根据自己的需求选择合适的生产者进行调用,并可以通过负载均衡等机制实现对多个生产者的调用和分配

Eureka服务注册与发现

Eureka是Netflix开源的一种服务注册与发现框架,也是Spring Cloud中常用的组件之一,提供服务注册和发现的功能,使得微服务应用程序可以方便地注册自己的服务并发现其他服务

在这里插入图片描述

ACID

ACID是指银行级一致性的协议,其全称为Atomicity(原子性)、Consistency(一致性)、Isolation(隔离性)和Durability(持久性)它是一个数据库事务在执行时需要满足的四个属性;如果一个事务在执行过程中发生了错误,比如发生了一个错误导致事务无法执行完成,那么需要回滚到事务开始前的状态,以保证数据的一致性

CAP

CAP是指在一个分布式系统中,数据的一致性通常被划分为三种类型:一致性(所有节点在同一时间读写数据)、可用性(所有节点可以读写数据,但是可能存在读到旧数据的情况)和分区容忍性(系统可以在节点发生故障的情况下继续运行)。CAP是一种数据一致性的理论,它强调了分布式系统中可能存在的限制和约束

Ribbon

"Ribbon"通常是指Netflix Ribbon,它是一个用于实现客户端负载均衡的开源Java库。Ribbon主要用于在微服务架构中进行客户端负载均衡和容错处理


🌼 结语:创作不易,如果觉得博主的文章赏心悦目,还请——点赞👍收藏⭐️评论📝


在这里插入图片描述

http://www.lryc.cn/news/106810.html

相关文章:

  • web题型
  • 使用curl和postman调用Azure OpenAI Restful API
  • 草莓叶病害数据集
  • 安卓音视频多对多级联转发渲染
  • 2023年电赛---运动目标控制与自动追踪系统(E题)OpenART mini的代码移植到OpenMV
  • SAP CAP篇十二:AppRouter 深入研究
  • HDFS中数据迁移的使用场景和考量因素
  • 科普 | 以太坊坎昆升级是什么
  • C# 一些知识整理
  • SpringBoot复习:(15)Spring容器的核心方法refresh是在哪里被调用的?
  • Android安卓实战项目(5)---完整的健身APP基于安卓(源码在文末)可用于比赛项目或者作业参考中
  • AutoSAR系列讲解(实践篇)11.2-存储处理与Block
  • K8s总结
  • 3.playbook剧本二
  • 【MySQL】视图与用户管理
  • LINUX系统监控工具ATOP的使用
  • [回馈]ASP.NET Core MVC开发实战之商城系统(五)
  • iPhone 8透明屏的透明度高吗?
  • Vue2 第十五节 组件间通信方式
  • maven的下载与安装
  • BroadcastChannel 实现浏览器tab无刷新通讯
  • 98. Python基础教程:try...except...finally语句
  • c语言实现简单的tcp客户端
  • RocketMQ详解及注意事项
  • 选择适合的项目管理系统,了解有哪些选择和推荐
  • linux基础命令-cd
  • MySQL数据库分库分表备份
  • PyTorch 中的累积梯度
  • 【面试精品】运维工程师需要具备的核心能力有哪些?
  • 微服务实战项目-学成在线-选课学习(支付与学习中心)模块