【微服务】Ribbon(负载均衡,服务调用)+ OpenFeign(服务发现,远程调用)【详解】

2024-09-08 12:20

本文主要是介绍【微服务】Ribbon(负载均衡,服务调用)+ OpenFeign(服务发现,远程调用)【详解】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.Ribbon(负载均衡,服务调用)
      • 1.1问题引出
      • 1.2 Ribbon负载均衡
      • 1.3 RestTemplate整合Ribbon
      • 1.4 指定Ribbon负载均衡策略
        • 1.4.1 配置文件
        • 1.4.2 配置类
        • 1.4.3 定义Ribbon客户端配置
        • 1.4.4 自定义负载均衡策略
    • 2.OpenFeign面向接口的服务调用(服务发现,远程调用)
      • 2.1 OpenFeign的使用
        • 2.1 .1创建一个fegin的api Module
        • 2.1 .2勇敢feginclient调用提供者的方法
      • 2.2 FeignClient日志输出
      • 2.3 服务调用的超时设置

1.Ribbon(负载均衡,服务调用)

1.1问题引出

学习完了注册中心相关知识,在微服务架构中,我们已经可以实现服务的注册与自动发现了。但是再来看看我们的代码

    @AutowiredDiscoveryClient discoveryClient;// 服务发现List<ServiceInstance> instances = discoveryClient.getInstances("服务名");// 选择一个服务提供者URI uri = instances.get(0).getUri();// 向选择的服务提供者发起请求ResponseEntity<String> response = template.getForEntity(uri.toString() + "/nacos/registry/hello?name={1}", String.class, name);

服务是可以有集群的,在发现了一个服务所有的实例之后,在一次服务调用过程中,我们还需要选择其中一个服务实例,发起调用请求,所以发起调用之前还存在着一个选择过程,这就涉及到了选择的策略问题,该按照何种策略选择出集群中的一个实例呢?在SpringCloud中有一个由Ribbon帮我们完成这一选择过程。

1.2 Ribbon负载均衡

Ribbon是一个客户端负载均衡器,能够给HTTP客户端带来灵活的控制。其实现的核心功能,就是一组选择策略,帮助我们在一个服务集群中,选择一个服务实例,并向该实例发起调用请求。它所支持的负载均衡策略如下:
在这里插入图片描述

1.3 RestTemplate整合Ribbon

我们希望,在使用RestTemplate发起请求的时候,能“自动选择”其所请求的服务实例,因此我们需要将RestTemplate与Ribbon进行整合。
首页,我们先在消费者服务工程中添加依赖

 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId></dependency>

在消费者中,因为nacos-discovery已经自己整合了ribbon依赖,所以实际上我们并不需要去添加该依赖
在这里插入图片描述
然后我们修改一下RestTemplate的配置类,添加@LoadBalance注解
在这里插入图片描述

@RestController
@RequestMapping("/call")
public class RegistryConsumerController {@AutowiredRestTemplate template;@GetMapping("/nacos")public String consumeNacos(String name) {// 注意这里调用的ip地址,使用的是服务名称,而不是真实的ipResponseEntity<String> response = template.getForEntity( "http://nacos-provider-8002/nacos/registry/hello?name={1}", String.class, name);String result = response.getBody();return result;}
}

1.4 指定Ribbon负载均衡策略

Ribbon中包含多种负载均衡策略,我们在使用Ribbon的时候,可以指定其负载均衡策略,指定的方式有两种,即配置文件和配置类。

1.4.1 配置文件
# 这里的users是我们的服务名称
users:ribbon:# 这一行配置的就是实现具体负载均衡策略实现类的全类名NFLoadBalancerRuleClassName:    com.netflix.loadbalancer.RandomRule
1.4.2 配置类
@Configuration
public class RandomRuleConfiguration {// 这里的xxxRule对应的就是RandomRule()@Beanpublic IRule ribbonRule() {return new RandomRule();}
}
1.4.3 定义Ribbon客户端配置

在这里插入图片描述

但是切记有一个地方需要注意,我们自己定义的配置类(比如上面的FooConfiguration配置类),不能被@ComponentScan扫描到,所以我们可以将其放在一个独立的,与扫描路径无重叠的包里,或者指明不被@ComponentScan注解扫描到,因为这样一来导致的结果就是,对所有服务调用的负载均衡都用的是同一个我们指定的,被扫描到的这个负载均衡策略

1.4.4 自定义负载均衡策略

我们可根据自己的需要,去定义自己的负载均衡策略,我们只需要自己实现IRule接口的实现类,在接口实现中,实现我们自己的负载均衡策略,并用类似于前面代码的配置方式,使我们自定义负载均衡策略生效。

public class MyBalanceRule extends AbstractLoadBalancerRule {public MyBalanceRule() {}@Overridepublic void initWithNiwsConfig(IClientConfig clientConfig) {}/*在该方法里实现负载均衡*/@Overridepublic Server choose(Object key) {List<Server> allServers = getLoadBalancer().getAllServers();// 简单粗暴的负载均衡策略return allServers.get(0);}
}

2.OpenFeign面向接口的服务调用(服务发现,远程调用)

现在我们的服务调用过程,又变得简单了一些,因为Ribbon帮助我们解决了,服务调用过程中的选择问题。再来看一下我们的服务调用代码
在这里插入图片描述
我们会发现,因为我们是使用RestTemplate这个Http客户端发起的Http协议的服务调用请求,因此在发起请求的时候,我们得自己构建请求url,请求参数,获取响应体数据等等,导致我们的代码和Restful风格的Http请求紧密耦合。

那么有没有办法,让我们在服务调用的时候与Restful的请求“解耦”,直接以Java代码中接口调用的方式,来完成服务的调用呢?

2.1 OpenFeign的使用

OpenFeign就可以帮助我们实现,让服务调用代码与Restful风格的Http请求解耦的功能。虽然,OpenFeign本身仅仅只是在客户端使用,但是因为使用了OpenFeign意味着服务的调用是面向Java接口的,而非HTTP API的,调用方式发生了改变,所以我们服务提供者工程的代码结构也要发生改变

直接拿一下商城项目使用到的openFeign实例在讲解
在这里插入图片描述
我们已经把单体架构拆分成了微服务,现在我们怎么
trade服务里面怎么快速高效率调用item服务呢?

2.1 .1创建一个fegin的api Module

在这里插入图片描述

@FeignClient("item-service") //里面的提供者的服务名称

在这里插入图片描述
注意路径一致
在这里插入图片描述

2.1 .2勇敢feginclient调用提供者的方法

两处调用都是直接调用 itemclient
在这里插入图片描述
在这里插入图片描述

2.2 FeignClient日志输出

当我们调用FeignClient发出请求的时候,如果我们希望能看到其发出的具体Http请求,我们可以通过配置来实现。

  1. 配置文件
# 这里的xxx表示我们自己的定义的FeignClient所在包的包名(比如: com.code.feign.consumer.api)
logging:level:xxx: debug
  1. 配置类
    在这里插入图片描述
@Configuration
public class DefaultFeignConfig {@Beanpublic Logger.Level feignLogLevel(){return Logger.Level.FULL;}
}

这样当我们,通过在对应的FeignClient对象上,调动方法,发起http请求的时候,对应的请求就会打印在控制体。

2.3 服务调用的超时设置

通常,一次远程调用过程中,服务消费者不可能无限制的等待服务提供者返回的结果,正常情况下,服务提供者的一次调用执行过程也不会执行很长时间(除非出现网络故障,或者服务提供者宕机等问题),所以为防止,在非正常情况下服务消费者在调用过程中的长时间阻塞等待,对于一次服务调用过程,我们会设置其超时时间。一次服务调用,超时未返回即认为调用失败。在使用Feign的时候,我们可以配置其超时时间。

ribbon:#指的是建立连接所用的时间,适用于网络状况正常的情况下,两端连接所用的时间ReadTimeout: 5000#指的是建立连接后从服务器读取到可用资源所用的时间ConnectTimeout: 5000

这篇关于【微服务】Ribbon(负载均衡,服务调用)+ OpenFeign(服务发现,远程调用)【详解】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

Django序列化中SerializerMethodField的使用详解

《Django序列化中SerializerMethodField的使用详解》:本文主要介绍Django序列化中SerializerMethodField的使用,具有很好的参考价值,希望对大家有所帮... 目录SerializerMethodField的基本概念使用SerializerMethodField的

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

Java强制转化示例代码详解

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录引入基本类型强制转换1.数字之间2.数字字符之间引入引用类型的强制转换总结引入在Java编程语言中,类型转换(无论

SpringCloud之consul服务注册与发现、配置管理、配置持久化方式

《SpringCloud之consul服务注册与发现、配置管理、配置持久化方式》:本文主要介绍SpringCloud之consul服务注册与发现、配置管理、配置持久化方式,具有很好的参考价值,希望... 目录前言一、consul是什么?二、安装运行consul三、使用1、服务发现2、配置管理四、数据持久化总

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

SpringCloud负载均衡spring-cloud-starter-loadbalancer解读

《SpringCloud负载均衡spring-cloud-starter-loadbalancer解读》:本文主要介绍SpringCloud负载均衡spring-cloud-starter-loa... 目录简述主要特点使用负载均衡算法1. 轮询负载均衡策略(Round Robin)2. 随机负载均衡策略(