【1.2】Java微服务:SpringCloud概论

✅作者简介:大家好,我是 Meteors., 向往着更加简洁高效的代码写法与编程方式,持续分享Java技术内容。
🍎个人主页:Meteors.的博客
💞当前专栏: 微服务
✨特色专栏: 知识分享
🥭本文内容:【1.2】Java微服务:SpringCloud概论
📚 **ps***  : 阅读这篇文章如果有问题或者疑惑,欢迎各位在评论区提出!


-----------------------------------------------------       目录       ----------------------------------------------------------

目录

一.  简介

1. 介绍

2.功能

二、特性

 三、组成

1. 各组件浏览(图)

 2. 各个组件具体介绍


--------------------------------------------------------------------------------------------------------------------------------

一.  简介

1. 介绍

Spring Cloud是一套用于构建分布式系统的开发工具集合,它基于Spring框架,提供了一系列组件和工具,帮助开发人员快速构建可伸缩、高可用的微服务架构。

2.功能

Spring Cloud致力于解决分布式系统中常见的问题,如服务注册与发现、负载均衡、断路器、配置管理、消息总线等。它提供了一系列基于Spring Boot的微服务模块,可以单独或组合使用,以满足不同的业务需求。

二、特性

  • Distributed/versioned configuration(分布式/版本化配置):用于将应用程序的设置和配置集中管理,并在整个系统中共享。这有助于确保所有服务都使用相同的配置。
  • Service registration and discovery(服务注册和发现):允许服务自动注册并公开其端点。其他服务可以通过服务发现查找和使用这些服务。
  • Routing(路由):用于将请求路由到正确的服务实例。可以将负载均衡和服务发现与路由结合起来,以保证高效和可靠的请求路由。
  • Service-to-service calls(服务间通信):用于在不同服务之间进行通信,可以使用REST API、RPC或消息代理等不同的方法。
  • Load balancing(负载均衡):用于将请求分发到多个服务实例,确保每个实例都能够处理适当的工作量。
  • Circuit Breakers(断路机制):用于防止故障的服务破坏整个系统。如果服务出现问题,则断路器可以中断流量并保持系统的稳定性。
  • Global locks(全局锁):用于协调分布式系统中的并发操作,以防止数据竞争和死锁问题。
  • Leadership election and cluster state(推举和集群状态):用于在分布式系统中选择一个主节点,并跟踪集群的状态。
  • Distributed messaging(分布式消息传递):用于异步通信和数据传输,在分布式系统中有很多不同的实现方式。 
​​​​                                      (ps:这里推荐浅过一遍,在后面配合具体实现理解)

 三、组成

1. 各组件浏览(图)

 2. 各个组件具体介绍

  1. 浏览控制和业务降级
    1. Hystrix:Netflix开源的一种容错和延迟容忍库,用于处理分布式系统中的故障和延迟。它实现了断路器模式,主要解决由于依赖服务故障导致的级联故障问题。
    2. Sentinel:阿里巴巴开源的一款轻量级流量控制和熔断降级框架。它提供了实时的流量控制、熔断降级、系统负载保护等功能,能够帮助开发者保护系统的稳定性和可靠性。
  2. 分布式配置
    1. SpringCloudConfig:一个用于集中管理和分发应用程序配置的开源框架。它提供了一种简单而强大的方式来管理不同环境下的配置,例如开发环境、测试环境和生产环境。
    2. Nacos:一个开源的动态服务发现、配置管理和服务管理平台。它提供了服务注册与发现、配置管理和服务治理等功能,能够帮助开发者构建弹性可伸缩的微服务架构。
  3. 服务链路监控
    1. Zipkin:一个开源的分布式跟踪系统,用于帮助开发者收集、存储和分析跨多个微服务的请求链路数据。它提供了一个可视化界面,展示了请求在不同微服务之间的调用关系和性能指标,有助于快速定位和解决分布式系统中的性能问题和故障。
    2. Sleuth:一个为 Spring Cloud 架构提供的分布式跟踪解决方案。它是基于 Zipkin 实现的,用于协调和捕获分布式系统中请求的跟踪信息。Sleuth 可以为微服务架构中的每个请求生成一个唯一的跟踪ID,并在整个请求链路中传递和记录该ID,以便进行分布式调用的跟踪和监控。
  4. 服务注册和发现
    1. Eureka:Netflix开源的一个基于RESTful的服务注册与发现组件,用于构建可扩展的、高可用的微服务架构。它的主要功能是实现服务的注册和发现,使得微服务可以自动地在集群中进行通信。
    2. Consul:一个开源的服务发现和配置工具,由HashiCorp公司开发。它提供了一种简单而可靠的方式来注册、发现和配置分布式系统中的服务。
  5. 统一网关路由
    1. SpringCloudGateway:Spring Cloud生态系统中的一个网关组件,用于构建基于微服务的API网关。它基于Spring Framework 5、Project Reactor和Spring Boot 2等技术栈,提供了一种简单、灵活和高效的方式来路由、过滤和转换请求。
    2. Zuul:Netflix开源的一个基于Java的边缘服务网关,用于构建和管理微服务架构中的API网关。它提供了一种简单、可扩展和高性能的方式来路由、过滤和转换请求。
  6. 远程过程调用
    1. OpenFeign:一个声明式的HTTP客户端框架,用于简化基于HTTP的服务之间的通信。它是Spring Cloud生态系统中的一部分,旨在提供一种优雅而简单的方式来定义和使用RESTful服务接口。
    2. Dubbo:一个由阿里巴巴开源的高性能RPC(远程过程调用)框架,用于简化分布式系统中服务之间的通信。它提供了基于Java的远程方法调用和服务治理的功能,旨在帮助开发者构建可扩展和高可用的分布式应用。

最后,

        相关内容会在专栏陆续更新,希望文章对你有所帮助..!

参考资料:

Spring Cloudicon-default.png?t=N6B9https://spring.io/projects/spring-cloud

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/21484.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

近5千情感两性职场个性测试文章ACCESS\EXCEL

这个数据库是将《1千条两性测试文章大全》《1千6个性测试文章大全》《1千多条职场测试文章大全》《1千条情感测试文章大全》四个数据库合并到一个数据表中,属于是文章型的心理测试内容,用在发公众号或者抖音等多媒体上与粉丝互动都是个不错的选择。 分类…

数据结构-串的模式匹配(25分) KMP算法/next数组/KMP的优化

先记录一个小坑。 int KMP() {getNext();int i 0, j 0;//写成下面这样&#xff0c;结果不对。原因是&#xff0c;当j-1时&#xff0c;循环条件-1 < strlen(P)被认为是false&#xff0c;会跳出循环while (i < strlen(T) && j < strlen(P)) {if (j -1 || T[…

【Pycharm2022.2.1】python编辑器最新版安装教程(包含2017-2022的所有版本win/mac/linux)

前言 嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! 永久安装 Pycharm&#xff08;2017-2022的win/mac/linux所有版本&#xff09;/ IntelliJ IDEA也可以, 按照本文教程所写的&#xff0c;具体步骤跟着下面的图文教程一步一步来就行&#xff0c;一分钟即可搞定&#xff0c;过…

SAP 消息号修改

各个模块的消息号修改&#xff08;转自于网上&#xff09; FI: OBA5|OFMG|OFPM CO: OPR4_ACT|OPR4_CK|OPR4_CKML|OPR4_CKPF|OPR4_KKA|OPR4_KKP|OPR4_KKS| OPR4_KKS1|OPR4_PPCOPP MM: OMRM|OKZZ|OMT4|OMCQ |O04C| SD: OVAH Others: OPR5|OPR1|OPR3|OPR6|OPR7|OPR8|OPR9|OP…

Windows Server 2012 R2 安装 Oracle RAC 11g R2

Windows Server 2012 R2 安装 Oracle RAC 11g R2 环境准备安装系统设置虚拟网络配置虚拟机网卡开机进行系统配置关闭防火墙设置网络系统高级设置修改注册表修改计算机名称设置账户控制RAC1 和 RAC2 的磁盘共享修改 hosts同步时间在 RAC1 RAC2 DATA 中安装 .net3.5在 DATA 中搭建…

MySQL常见问题处理(三)

MySQL 常见问题解决 夕阳留恋的不是黄昏&#xff0c;而是朝阳 上一章简单介绍了MySQL数据库安装(二), 如果没有看过, 请观看上一章 一. root 用户密码忘记&#xff0c;进行重置操作 复制内容来源链接: https://blog.csdn.net/weixin_48927364/article/details/123556927 一.…

开发手册|Java后端开发规范重点条目整理

Ps&#xff1a;部分熟知的开发规范未收录在本文中&#xff01; 一、编程规约 1.1 命名风格 代码中的命名严禁使用拼音与英文混合的方式 alibaba / taobao / youku / hangzhou 等国际通用的名称可视同英文 类名使用大驼峰的形式命名&#xff0c;例如 UpperCameCase 方法、参数…

React 之 Redux - 状态管理

一、前言 1. 纯函数 函数式编程中有一个非常重要的概念叫纯函数&#xff0c;JavaScript符合函数式编程的范式&#xff0c;所以也有纯函数的概念 确定的输入&#xff0c;一定会产生确定的输出 函数在执行过程中&#xff0c;不能产生副作用 2. 副作用 表示在执行一个函数时&a…

《江苏经济报》报道 | 光影逐梦,“苏”写影视工业“诗和远方”企业新闻

近日&#xff0c;《江苏经济报》就蓝海创意云影视动画渲染服务进行了独家专题报道。 云上生产&#xff0c;数字技术创新电影工业流程 三年疫情&#xff0c;不仅阻隔了电影工业产业链上下游资源的对接协作&#xff0c;也放大了产业在地域和行业中人财物资源的不平衡。太湖湖畔的…

jasypt 加密和解密

摘要 博主写作此文时&#xff0c;该软件的最新版本为&#xff1a;Jasypt 1.9.3 RELEASED Jasypt 简介 Jasypt 是一个 Java 库&#xff0c;它允许开发人员以最小的努力为项目添加基本的加密功能&#xff0c;而无需深入了解密码学的工作原理。 Jasypt 特征 Jasypt 提供简单的单…

【Android-java】Parcelable 是什么?

Parcelable 是 Android 中的一个接口&#xff0c;用于实现将对象序列化为字节流的功能&#xff0c;以便在不同组件之间传递。与 Java 的 Serializable 接口不同&#xff0c;Parcelable 的性能更高&#xff0c;适用于 Android 平台。 要实现 Parcelable 接口&#xff0c;我们需…

Jmeter使用总结

文章目录 一、基本使用1.1. 基本使用1.2 主要元件 二、常用场景2.1 切换工具语言2.2 调整jmeter内存2.3 添加请求头2.4 添加断言2.5 添加http默认请求值2.6 基于吞吐量压测2.7 基于文件作为请求参数 一、基本使用 1.1. 基本使用 创建<测试计划>测试计划下添加<线程组…

【分布式系统】聊聊系统监控

对于分布式系统来说&#xff0c;出现故障的是常有的事情&#xff0c;如何在短时间内找到故障的原因&#xff0c;排除故障是非常重要的&#xff0c;而监控系统是就像系统的眼睛可以通过分析相关数据&#xff0c;进一步管理和运维整个分布式系统。 监控系统的的基本功能包含 全…

使用 Simulink 进行 STM32 编程

目录 介绍 所需材料 步骤 1&#xff1a;在MATLAB中设置STM32-MAT软件路径步骤 2&#xff1a;在STM32CubeMX中创建一个项目步骤 3&#xff1a;配置时钟和 GPIO 引脚步骤 4&#xff1a;项目经理并生成代码步骤 5&#xff1a;在 Simulink 中创建模型步骤 6&#xff1a;在模型中插…

【leetcode】24. 两两交换链表中的节点(medium)

给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题&#xff08;即&#xff0c;只能进行节点交换&#xff09;。 /*** Definition for singly-linked list.* public class ListNode {* in…

QT-如何生成唯一ID

在Qt中&#xff0c;我们可以使用QUuid类来生成唯一的ID。QUuid是一个用于操作通用唯一标识符&#xff08;UUID&#xff09;的类&#xff0c;它可以生成符合RFC4122标准的UUID。 以下是一个示例代码&#xff0c;演示了如何使用QUuid生成唯一的ID&#xff1a; #include <QAp…

PHP-简单项目引起的大麻烦--【白嫖项目】

强撸项目系列总目录在000集 PHP要怎么学–【思维导图知识范围】 文章目录 本系列校训本项目使用技术 首页小插曲小插曲完了么&#xff1f;必要的项目知识PHPThinkPHPThinkPHP的MVCThinkTemplateThinkPHP 6和ThinkPHP 5 phpStudy 设置导数据库展示页面数据库表结构项目目录如图…

ROS版本的ORB-SLAM3用RealSense D455相机实时运行测试

配置环境 1. C11 检查G版本&#xff0c;查看是否支持C11 一般g版本大于4.7即可 g -v 2. Pangolon 地址&#xff1a;https://github.com/stevenlovegrove/Pangolin 先安装OpenGL&#xff0c;Glew ### 编译orb-slam3发现pangolin编译错误排查的环境问题 sudo apt install p…

如何用arduino uno主板播放自己想要的曲子。《我爱你中国》单片机版本。

目录 一.效果展示 二.基本原理 三.电路图 四.代码 一.效果展示 arduino播放《我爱你中国》 二.基本原理 利用arduino uno单片机实现对蜂鸣器振动频率的调节&#xff0c;基于PWM控制系统通过代码实现控制。 三.电路图 四.代码 //main.uno #define Buzzer 2int PotBuffer …

Web3到底是个啥?

Web3是近两年来科技领域最火热的概念之一&#xff0c;但是目前对于Web3的定义却仍然没有形成标准答案&#xff0c;相当多对于Web3的理解&#xff0c;都是建立在虚拟货币行业&#xff08;即俗称的“币圈”&#xff09;的逻辑基础之上的。 区块链服务网络&#xff08;BSN&#x…