【微服务】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

相关文章

C语言进阶(预处理命令详解)

《C语言进阶(预处理命令详解)》文章讲解了宏定义规范、头文件包含方式及条件编译应用,强调带参宏需加括号避免计算错误,头文件应声明函数原型以便主函数调用,条件编译通过宏定义控制代码编译,适用于测试与模块... 目录1.宏定义1.1不带参宏1.2带参宏2.头文件的包含2.1头文件中的内容2.2工程结构3.条件编

PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例

《PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例》词嵌入解决NLP维度灾难,捕捉语义关系,PyTorch的nn.Embedding模块提供灵活实现,支持参数配置、预训练及变长... 目录一、词嵌入(Word Embedding)简介为什么需要词嵌入?二、PyTorch中的nn.Em

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

mybatis中resultMap的association及collectio的使用详解

《mybatis中resultMap的association及collectio的使用详解》MyBatis的resultMap定义数据库结果到Java对象的映射规则,包含id、type等属性,子元素需... 目录1.reusltmap的说明2.association的使用3.collection的使用4.总

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

Apache Ignite缓存基本操作实例详解

《ApacheIgnite缓存基本操作实例详解》文章介绍了ApacheIgnite中IgniteCache的基本操作,涵盖缓存获取、动态创建、销毁、原子及条件更新、异步执行,强调线程池注意事项,避免... 目录一、获取缓存实例(Getting an Instance of a Cache)示例代码:二、动态

Linux之platform平台设备驱动详解

《Linux之platform平台设备驱动详解》Linux设备驱动模型中,Platform总线作为虚拟总线统一管理无物理总线依赖的嵌入式设备,通过platform_driver和platform_de... 目录platform驱动注册platform设备注册设备树Platform驱动和设备的关系总结在 l