Feign 第一次调用为什么会很慢?

feign调用的大致过程?
Feign进行远程调用的,这里面包括,注册中心、负载均衡、FeignClient之间的关系,微服务通过不论是eureka、nacos也好注册到服务端,Feign是靠Ribbon做负载的,而Ribbon需要拿到注册中心的服务列表,将服务进行负载缓存到本地,然后FeignClient客户端在进行调用。
对应的流程图如下:
Ribbon是如何进行负载的,也就是如何获取nacos、eureka的服务列表,这个很关键。
在这里插入图片描述
这里的核心就是Ribbon的注册配置核心类的接口,也是靠LoadBalancer做负载的 无非就是ILoadBalancer接口的方法。
我们看下ILoadBalancer接口的方法。
在这里插入图片描述
以上的负载均偶默认的ZoneAwareLoadBalancer 通过继承父类DynamicServerListLoadBalancer的restOfInit方法,里面比较重要的两个方法,enableAndInitLearnNewServersFeature和updateListOfServers方法。在这里插入图片描述
enableAndInitLearnNewServersFeature方法里面

LOGGER.info("Using serverListUpdater {}", serverListUpdater.getClass().getSimpleName());
serverListUpdater.start(updateAction);

ServerListUpdater.start方法的实现,通过自定义线程去拿,这就是获取服务列表;
在这里插入图片描述
什么是Ribbon负载均衡策略?
服务列表获取说了,当然负载均衡的策略这块也有必要讲一下,主要有七种;
A:RoundRobinRule(轮询策略,按照服务顺序依次循环调用)
B:WeightedResponseTimeRule(权重比策略,优先选择权重比高的服务,也就是服务响应时间比C:较短的,响应时间越长权重比越低)
D:RandomRule(随机策略,服务提供者列表随机选择一个服务)
E:BestAvailableRule(最小连接数策略,获取服务列表中连接数最小的服务实例)
F:RetryRule(重试策略,重试获取已经失效的服务,指定时间没有获取到返回NULL)
G:AvailabilityFilteringRule(可用性敏感策略,过滤非健康服务实例,选择lianji)
H:ZoneAvoidanceRule(区域敏感策略)
Ribbon-eager-load(饥饿加载)模式
Ribbon对于负载Client是在服务启动后,发生调用的时候才会去创建Client,所以在第一次发生http请求调用的时候,不光要算上http的请求时间,还要算上Client的创建时间,所以第一次调用的时候才会很慢,写个方法调用下;

@GetMapping("/requestSystem2Api")
public String requestSystem2Api(){long startTime = System.currentTimeMillis();R<String> stringR = iTestServiceClient.testRequestMethod();if (null !=stringR){log.info("接口返回:"+stringR.getMsg());}long needTime = System.currentTimeMillis() - startTime;log.info("接口调用需要的时间:"+needTime);return "";
}

从调用日志可以看出,第一次调用System2服务,Ribbon的DynamicServerListLoadBalancer会将feign客户端进行负载,然后进行调用,第一次调用的时间就是会长一些,第二次调用直接进行请求可以看到调用时间很快。
在这里插入图片描述
如何解决?
开启Ribbon饥饿加载
在这里插入图片描述
在项目启动的时候,可以从日志看到,已经把Lxlxxx-system2服务进行加载,从而避免了第一次请求超时的情况;
在这里插入图片描述
最后
其实这种饥饿加载模式,类似于“客户端负载预热”的一个操作,项目启动的时候进行加载,防止服务之间调用可以因为数据量、业务逻辑处理复杂性导致接口超时,如果你的服务之间调用业务处理比较复杂、且慢,不妨可以试试这种解决方式。
需要咨询更多的问题 欢迎识别下方二维码开启我们的故事吧。
在这里插入图片描述

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

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

相关文章

从零开始构建现代深度学习框架:数据支持、网站链接与代码步骤

文章目录 一、数据支持二、网站链接三、代码步骤1. 导入必要的库和模块2. 加载和预处理数据&#xff08;以MNIST为例&#xff09;3. 定义模型结构4. 编译模型5. 训练模型6. 评估模型 一、数据支持 在构建深度学习框架的过程中&#xff0c;数据是不可或缺的。以下是一些可能用到…

android进阶-Binder

参考&#xff1a;Android——Binder机制-CSDN博客 机制&#xff1a;Binder是一种进程间通信的机制 驱动&#xff1a;Binder是一个虚拟物理设备驱动 应用层&#xff1a;Binder是一个能发起进程间通信的JAVA类 Binder相对于传统的Socket方式&#xff0c;更加高效Binder数据拷贝…

JavaScript的未来发展趋势,探索JavaScript中最新技术(JavaScript可视化编程到服务端渲染)

简介&#xff1a;JavaScript生态系统是一个充满机遇的领域&#xff0c;它从创造性的可视化编程到高效的服务端渲染&#xff0c;它的的技术生态系统正在迅速演变&#xff0c;相关技术一直处于不断发展的前沿。这里将带您深入探索目前 JavaScript 中最近最火的技术趋势&#xff0…

类(Classes)在TypeScript中的使用:面向对象编程的基石

类&#xff08;Classes&#xff09;在TypeScript中的使用&#xff1a;面向对象编程的基石 引言 类&#xff08;Classes&#xff09;是TypeScript中实现面向对象编程&#xff08;OOP&#xff09;的核心概念之一。它们允许你通过封装、继承和多态性来构建复杂的应用。本文将深入…

为什么人力资源(HR)工资低?原因在这

为什么做人力资源的&#xff0c;工资都很低&#xff1f; 对于HR工资低的问题&#xff0c;最需要讨论的部分是——HR 究竟有什么价值&#xff1f; 有很多人没想过但会遇到的困惑&#xff1a; 一、为什么人事工资那么低&#xff1f; 同理&#xff0c;也有很多人不明白自己为什…

MyBatis 一对多查询(联合查询 ResultMap 映射 和 子查询映射)

前言&#xff1a; 在数据库操作中&#xff0c;我们可能习惯了单表、连表操作&#xff0c;突然然你来进行一对多操作&#xff0c;你还会吗&#xff1f; 什么是一对多&#xff1f; 一对多是最基础的表关系&#xff0c;简单来说就是 A 表中的一条数据对应 B 表中的多条数据&…

豆芽机置入语音芯片WTN6040-8S:开启智能生活新篇章,让豆芽制作更便捷有趣

豆芽机的开发背景&#xff1a; 豆芽作为一种营养丰富、味道鲜美的食品&#xff0c;深受广大消费者的喜爱。然而&#xff0c;传统的豆芽生产过程繁琐&#xff0c;需要耗费大量的时间和人力&#xff0c;且存在生产效率低、质量不稳定等问题。随着人们生活节奏的加快和对健康饮食的…

DataLab-数据分析的Ai辅助工具

添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09;DataLab是一个由DataCamp提供的强大在线数据分析平台&#xff0c;它通过AI技术简化了数据处理流程&#xff0c;使得用户无需编程或数据分析的高级技能即可快速获取数据洞察。它支持多种数据源&#xff0c;包…

C++多态实现原理详解

阅读引言&#xff1a; 我想象了一下&#xff0c; 假如人有突然问我什么是多态&#xff0c; 我该如何给别人说清楚呢&#xff1f;所以写下这篇文章&#xff0c; 希望大家看完有所收获。 ①. 开胃小菜 先看这样一个开胃小菜 这里我有点小小的疑惑&#xff0c; 大小为啥是1。 在C…

Python | Leetcode Python题解之第74题搜索二维矩阵

题目&#xff1a; 题解&#xff1a; class Solution:def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:row,col len(matrix),len(matrix[0])row_l,row_r 0,row-1while row_l < row_r:m (row_lrow_r)//2if target < matrix[m][0]:row_r m-1…

微信小程序开发秘籍:无缝集成微信登录功能

微信小程序开发秘籍&#xff1a;无缝集成微信登录功能 在微信生态内开发小程序&#xff0c;无缝集成微信登录功能是提升用户体验、实现用户身份管理的关键一步。本篇文章将带你深入探索如何在微信小程序中实现一键登录&#xff0c;从基础概念到代码实战&#xff0c;每一步都力…

impdp 高级用法

1.从现有的测试库上导出表结构数据&#xff0c;导入到目标库&#xff0c;除去索引和约束&#xff1b;没有索引和约束的额外开销&#xff0c;单纯导数据会很快。 2.现有生产库上数据导出&#xff0c;尽可能采用高并发&#xff1b;考虑到新旧服务器CPU核数较多&#xff0c;准备采…

协智优能技术负责人15-20K面经

这家公司是初创公司&#xff0c;一个小办公室&#xff0c;面试体验还不错&#xff0c;面试流程&#xff1a;1、进去先做笔试题&#xff0c;笔试题有前端&#xff0c;ai&#xff0c;java&#xff0c;小程序&#xff0c;开发流程 2、然后是面试官面试 【笔试题】 1、session和coo…

使用 Docker 部署 VS Code in The Browser

1&#xff09;介绍 GitHub&#xff1a;https://github.com/coder/code-server 在日常学习工作中&#xff0c;Vscode 已成为我们首选的代码编辑器。然而&#xff0c;其局限性在于当我们从家到公司移动时&#xff0c;难以保持连续的编码体验。针对这一痛点&#xff0c;虽然市面上…

oracle 数据库与服务、实例与SID、表空间、用户与表模式

一、数据库与数据库服务: 概念:就是一个数据库的标识,在安装时就要想好,以后一般不修改,修改起来也麻烦,因为数据库一旦安装,数据库名就写进了控制文件,数据库表,很多地方都会用到这个数据库名。是数据库系统的入口,它会内置一些高级权限的用户如SYS,SYSTEM等。我们…

11.买卖股票的最佳时机Ⅰ

文章目录 题目简介题目解答解法一&#xff1a;一次遍历代码&#xff1a;复杂度分析&#xff1a; 题目链接 大家好&#xff0c;我是晓星航。今天为大家带来的是 买卖股票的最佳时机面试题Ⅰ 相关的讲解&#xff01;&#x1f600; 题目简介 题目解答 解法一&#xff1a;一次遍历…

怎么把手机ip地址变成了外省

在日常使用中&#xff0c;有时我们可能因为某些原因需要快速切换手机的IP地址&#xff0c;特别是当需要从一个省份切换到另一个省份的IP时。这种需求可能来源于网络访问限制、地理位置相关服务的使用、或者网络安全等方面的考虑。那么&#xff0c;怎么把手机IP地址变成外省呢&a…

Adobe Premiere Pro v24.3.0 解锁版 (领先的视频编辑软件)

前言 Adobe Premiere Pro&#xff08;简称PR&#xff09;是一款知名的专业视频编辑软件&#xff0c;数字视频剪辑软件。主要用来编辑视频和音频&#xff0c;可以在RGB和YUV色彩空间中以高达32位色彩的视频分辨率对4K和更高质量的视频文件进行编辑&#xff0c;支持VST音频插件和…

处理用户输入

目录 一、传递参数 1.1 读取参数 1.2 读取脚本名 二、跟踪参数 三、移动参数 四、处理选项 4.1 查找选项 4.1.1 处理简单选项 4.1.2 分离参数和选项 4.1.3 处理含值的选项 五、选项标准化 5.1 使用 getopt 命令 5.1.1 命令格式 5.1.2 在脚本中使用getopt 5.2 使用…

C++ 搜索二叉树

目录 1.二叉搜索树概念 2. 实现二叉搜索树 2.1. 二叉搜索树的插入 2.2查找 2.3删除节点 3.二叉树的应用&#xff08;KV结构&#xff09; 1.二叉搜索树概念 二叉搜索树又称二叉排序树&#xff0c;它或者是一棵空树&#xff0c;或者是具有以下性质的二叉树: 若它的左子树不为…