SpringCloud Netflix和SpringCloud Alibaba核心组件

2024-06-20 00:20

本文主要是介绍SpringCloud Netflix和SpringCloud Alibaba核心组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.SpringCloud Netflix组件

1.1 Netflix Eureka-服务注册发现

        Eureka 是一种用于服务发现 的组件,它是一个基于 REST 的服务,用于定位运行在 AWS 弹性计算云(EC2)中的中间层服务,以便它们可以相互通讯。

注册: 每个服务都向Eureka登记自己提供服务的元数据,包括服务的ip地址、端口号、版本号、通信协议等。

发现:eureka注册的服务之间调用不需要指定服务地址,而是通过服务名向注册中心咨询,并获取所有服务实例清单(缓存到本地),然后实现服务的请求访问。

1.2 Netflix Ribbon-客户端负载均衡

负载均衡分为服务器端负载均衡和客户端负载均衡

服务器端负载均衡:Nginx、F5等等,请求到达服务器之后由这些负载均衡器根据⼀定的算法将请求路由到⽬标服务器处理。

客户端负载均衡:Ribbon 是一个基于 HTTP 和 TCP 的客户端负载均衡器,服务间发起请求的时候,基于Ribbon做负载均衡,从⼀个服务的多台机器中选择⼀台 (被调 用方的服务地址有多个),Ribbon也是通过发起http请求,来进行的调用,只不过是通过调用服务名的地址来实现的。Ribbon不用去具体请求服务实例的ip地址或域名了,但是每调用一个接口都还要手动去发起Http请求。

负载均衡策略参考:SpringCoud Ribbon配置和实现原理-CSDN博客

1.2.1 Feign远程调用组件

Feign是Netflix开发的⼀个轻量级RESTful的HTTP服务客户端,以Java接⼝注解的⽅式调⽤Http请求,类似于dubbo,服务消费者拿到服务提供者的接⼝,然后像调用本地接⼝⽅法⼀样去调用,实际发出的是远程的请求。

本质:封装了Http调用流程,更符合⾯向接口化的编程习惯,类似于Dubbo的服务调用,基于代理实现。

Feign = RestTemplate+Ribbon+Hystrix

 1.3 Netflix Hystrix-熔断器

 Hystrix 是一个用于处理分布式系统的延迟和容错的库,用于隔离访问远程服务,防止出现级联失败,解决了服务雪崩问题,从而提高系统的弹性。

Hystrix解决雪崩问题的手段:

服务熔断:当扇出链路的某个微服务不可⽤或者响应时间太⻓时,熔断该节点微服务的调⽤,进⾏服务的降级,快速返回错误的响应信息。当检测到该节点微服务调⽤响应正常后,恢复调⽤链路。

熔断的几种处理方式:

@HystrixCommand(commandProperties = {// 隔离策略,这个配置项默认是THREAD(线程),另外一个选项是SEMAPHORE(信号量),在信号量策略下无法使用超时时间设置。@HystrixProperty(name = HystrixPropertiesManager.EXECUTION_ISOLATION_STRATEGY, value = "THREAD"),// 单实例vivo接口最大并发请求数150,多处的直接拒绝@HystrixProperty(name = HystrixPropertiesManager.EXECUTION_ISOLATION_SEMAPHORE_MAX_CONCURRENT_REQUESTS, value = "1"),// 线程超时时间,10秒@HystrixProperty(name = HystrixPropertiesManager.EXECUTION_ISOLATION_THREAD_TIMEOUT_IN_MILLISECONDS, value = "100"),//错误百分比条件,达到熔断器最小请求数后错误率达到百分之多少后打开熔断器@HystrixProperty(name = HystrixPropertiesManager.CIRCUIT_BREAKER_ERROR_THRESHOLD_PERCENTAGE, value = "10"),//断容器最小请求数,达到这个值过后才开始计算是否打开熔断器@HystrixProperty(name = HystrixPropertiesManager.CIRCUIT_BREAKER_REQUEST_VOLUME_THRESHOLD, value = "3"),// 默认5秒; 熔断器打开后多少秒后 熔断状态变成半熔断状态(对该微服务进行一次请求尝试,不成功则状态改成熔断,成功则关闭熔断器@HystrixProperty(name = HystrixPropertiesManager.CIRCUIT_BREAKER_SLEEP_WINDOW_IN_MILLISECONDS, value = "5000")})

服务降级:当接口不可用、超时、错误率高于阈值时自动调用fallbackMethod指定的方法处理请求,称为服务降级,通过在@HystrixCommand注解上配置fallbackMethod参数指定降级后调用的方法,fallbackMethod方法可以直接返回错误,或者提供带缓存的高性能的实现等,如果fallbackMethod也不可用,会发生熔断报错返回。

服务限流:流量控制就是限制业务访问的 qps(每秒处理请求数量),避免服务因流量突增而故障.比如有一个微服务能承受的最大 qps 是 2,也就是每秒钟最多处理两个请求,但是现在有一百个请求涌过来了,那他不得被达成筛子了,但是 sentinel 会根据这个 qps 的限制,去处理请求然后释放(这就像是有大量的水要涌入的时候,会先经过一个漏斗,通过这个漏斗,将水的流量限制住),这个时候,就可以有效的避免出现故障(超出的请求会被拦截,默认会报错,但也可以配置成 排队等待、预热)。
线程隔离:Hystrix为每个服务调配一个小的线程池,如果线程池已满,调用这个服务将被立即拒绝

1.4 Netflix Zuul-服务网关

Zuul 是一种提供动态路由、监控、弹性、安全等功能的边缘服务。从2.2.10.RELEASE之后不再升级,SpringCloud改用Gateway作为网关。

1.4.1 GateWay核心

路由(route):最基础的部分,由⼀个ID、一个目标URL、⼀系列的断⾔(匹配条件判断)和 Filter过滤器(精细化控制)组成。如果断言为true,则匹配该路由。

断⾔(predicates):匹配Http请求中的所有内容(包括请求头、请求参数等)

过滤器(filter)请求之前或者之后执⾏业务逻辑。

Zuul、Gateway、Nginx的区别_zuul、gateway和nginx有什么区别-CSDN博客

1.5 Spring Cloud Config-配置中心

Spring Cloud Config 是一个使得分布式系统中的外部配置管理变得简单的系统,它是静态配置,配合springcloud bus实现动态配置

Spring Cloud Config 配置中心_spring-cloud-config-server-CSDN博客

2 SpringCloud Alibaba组件

2.1 .Nacos-服务注册发现和配置中心

一个更易于构建云原生应用的动态服务注册和发现、配置中心和服务管理平台。nacos-discovery 服务注册发现,nacos-config配置中心

2.2 Dubbo RPC--服务间通信

一种高性能的Java RPC框架,用于服务间通信。是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。

2.3 Sentinel-熔断器

面向微服务架构的高可用流量控制组件,流量控制,服务熔断,服务限流。

2.4 RocketMQ

一种开源的分布式消息系统,消息队列

2.5 Seata

一种分布式事务解决方案。

3.Cloud Netfilx和Cloud alibaba对比

参考:

https://zhuanlan.zhihu.com/p/364330271?utm_id=0

SpringCloudAlibaba常用组件_springcloudalibaba组件-CSDN博客

这篇关于SpringCloud Netflix和SpringCloud Alibaba核心组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1076567

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

Java中的.close()举例详解

《Java中的.close()举例详解》.close()方法只适用于通过window.open()打开的弹出窗口,对于浏览器的主窗口,如果没有得到用户允许是不能关闭的,:本文主要介绍Java中的.... 目录当你遇到以下三种情况时,一定要记得使用 .close():用法作用举例如何判断代码中的 input

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S