如何优雅地为 Axios 配置失败重试与最大尝试次数

        在 Vue 3 中,除了使用自定义的 useRequest 钩子函数外,还可以通过 axios 的拦截器 axios-retry 插件实现接口请求失败后的重试逻辑。以下是两种具体方案的实现方式:

方案一:使用 axios 拦截器实现重试

       实现步骤: 通过 axios 的响应拦截器捕获错误,并在拦截器内部实现重试逻辑。

        1、配置 axios 实例:在 Vue 项目的入口文件(如 main.js)中配置 axios。

        2、添加响应拦截器:在拦截器中捕获错误,并根据条件进行重试。

        3、递归重试:在拦截器中控制重试次数和延迟。

// main.js 或单独的 axios 配置文件
import axios from 'axios';// 配置 axios 实例
const axiosInstance = axios.create({baseURL: '/api', // 根路径timeout: 10000, // 超时时间
});// 响应拦截器:处理错误并重试
axiosInstance.interceptors.response.use((response) => response, // 成功响应直接返回async (error) => {const config = error.config;const status = error.response?.status;const maxRetries = 5; // 最大重试次数const retryDelay = 1000; // 重试间隔(毫秒)// 如果没有重试次数或达到最大次数,直接抛出错误if (!config || !config._retryCount) {config._retryCount = 0;}if (config._retryCount >= maxRetries) {return Promise.reject(error);}// 增加重试次数config._retryCount += 1;// 只对特定状态码(如 408、5xx)重试if ([408, 500, 502, 503, 504].includes(status) ||(status === 401 && config.url.includes('/refresh-token')) // 示例:401 时重试刷新 token) {// 等待一段时间后重试await new Promise((resolve) => setTimeout(resolve, retryDelay * config._retryCount));// 重新发送请求return axiosInstance(config);}// 其他错误直接抛出return Promise.reject(error);}
);// 导出配置好的 axios 实例
export default axiosInstance;

使用示例(在 Vue 组件中)

<template><div><button @click="fetchData">获取数据</button><div v-if="loading">加载中...</div><div v-else-if="data">数据:{{ data }}</div><div v-else-if="error">错误:{{ error.message }}</div></div>
</template><script setup>
import axiosInstance from '@/utils/axios'; // 导入配置好的 axios 实例
import { ref } from 'vue';const loading = ref(false);
const data = ref(null);
const error = ref(null);const fetchData = async () => {try {loading.value = true;const response = await axiosInstance.get('/data');data.value = response.data;error.value = null;} catch (err) {error.value = err;} finally {loading.value = false;}
};
</script>

        1、拦截器全局生效:所有通过 axiosInstance 发起的请求都会经过拦截器,自动处理重试逻辑。可通过配置 config 参数(如 config._retryCount)控制重试次数。

        2、重试条件:根据 HTTP 状态码(如 408、5xx)决定是否重试。可扩展为根据业务逻辑(如 token 过期后刷新)触发重试。

        3、递归重试:通过 axiosInstance(config) 重新发送请求,递归调用拦截器。需要手动维护 config._retryCount 来计数。

方案二:使用 axios-retry 插件

        通过 axios-retry 插件快速实现重试逻辑,无需手动编写递归逻辑。

        1、安装插件

npm install axios-retry

        2、配置 axios 实例

// main.js 或单独的 axios 配置文件
import axios from 'axios';
import axiosRetry from 'axios-retry';const axiosInstance = axios.create({baseURL: '/api',timeout: 10000,
});// 配置重试策略
axiosRetry(axiosInstance, {retries: 5, // 最大重试次数retryDelay: (retryCount) => {return retryCount * 1000; // 指数退避:1s、2s、3s...},retryCondition: (error) => {// 自定义重试条件(如针对特定状态码)if (error.response) {return [408, 500, 502, 503, 504].includes(error.response.status);}return axiosRetry.isNetworkError(error); // 网络错误自动重试},
});export default axiosInstance;

        3、使用示例(与方案一相同)

<template><!-- 同上 -->
</template><script setup>
import axiosInstance from '@/utils/axios'; // 已配置重试的 axios 实例
// 同上
</script>

关键点说明

        1、插件优势:开箱即用,代码简洁。支持自定义重试条件、延迟策略(如指数退避)。

内置对网络错误(如超时)的自动重试。

        2、灵活性:可通过 retryCondition 函数灵活控制重试条件。支持 retryDelay 函数实现动态延迟(如指数退避)。


对比与选择

方案优点缺点
拦截器手动实现完全自定义逻辑,无依赖代码冗余,需手动维护计数器
axios-retry 插件简单易用,开箱即用需引入第三方依赖

注意事项

        1、避免无限循环:必须设置最大重试次数(如 maxRetries 或 retries 参数)。确保重试条件不会无限触发(如 401 未授权 需结合 token 刷新逻辑)。

        2、错误类型区分:对于 4xx 客户端错误(如 400、401、403),通常不建议重试,需业务逻辑处理(如跳转登录页)。对 5xx 服务端错误(如 500、503)或网络错误(如超时),可安全重试。

        3、性能优化:使用 指数退避(如 retryDelay: (count) => Math.pow(2, count) * 1000)减少并发重试的压力。结合 限流(如 maxRetries 与 retryDelay 组合)避免频繁请求。

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

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

相关文章

【Leetcode刷题随笔】242.有效的字母异位词

1. 题目描述 给定两个仅包含小写字母的字符串 s 和 t &#xff0c;编写一个函数来判断 t 是否是 s 的 字母异位词。 字母异位词定义&#xff1a;两个字符串包含的字母种类和数量完全相同&#xff0c;但顺序可以不同&#xff08;例如 “listen” 和 “silent”&#xff09;。 …

示例:spring xml+注解混合配置

以下是一个 Spring XML 注解的混合配置示例&#xff0c;结合了 XML 的基础设施配置&#xff08;如数据源、事务管理器&#xff09;和注解的便捷性&#xff08;如依赖注入、事务声明&#xff09;。所有业务层代码通过注解简化&#xff0c;但核心配置仍通过 XML 管理。 1. 项目结…

Crawl4AI:打破数据孤岛,开启大语言模型的实时智能新时代

当大语言模型遇见数据饥渴症 在人工智能的竞技场上&#xff0c;大语言模型&#xff08;LLMs&#xff09;正以惊人的速度进化&#xff0c;但其认知能力的跃升始终面临一个根本性挑战——如何持续获取新鲜、结构化、高相关性的数据。传统数据供给方式如同输血式营养支持&#xff…

【机器学习-周总结】-第4周

以下是本周学习内容的整理总结&#xff0c;从技术学习、实战应用到科研辅助技能三个方面归纳&#xff1a; 文章目录 &#x1f4d8; 一、技术学习模块&#xff1a;TCN 基础知识与结构理解&#x1f539; 博客1&#xff1a;【时序预测05】– TCN&#xff08;Temporal Convolutiona…

Mysql--基础知识点--79.1--双主架构如何避免回环复制

1 避免回环过程 在MySQL双主架构中&#xff0c;GTID&#xff08;全局事务标识符&#xff09;通过以下流程避免数据回环&#xff1a; 1 事务提交与GTID生成 在Master1节点&#xff0c;事务提交时生成一个全局唯一的GTID&#xff08;如3E11FA47-71CA-11E1-9E33-C80AA9429562:2…

安宝特科技 | AR眼镜在安保与安防领域的创新应用及前景

随着科技的不断进步&#xff0c;增强现实&#xff08;AR&#xff09;技术逐渐在多个领域展现出其独特的优势&#xff0c;尤其是在安保和安防方面。AR眼镜凭借其先进的功能&#xff0c;在机场、车站、海关、港口、工厂、园区、消防局和警察局等行业中为安保人员提供了更为高效、…

Linux第十讲:进程间通信IPC

Linux第十讲&#xff1a;进程间通信IPC 1.进程间通信介绍1.1什么是进程间通信1.2为什么要进程间通信1.3怎么进行进程间通信 2.管道2.1理解管道2.2匿名管道的实现代码2.3管道的五种特性2.3.1匿名管道&#xff0c;只能用来进行具有血缘关系的进程进行通信(通常是父子)2.3.2管道文…

微信小程序通过mqtt控制esp32

目录 1.注册巴法云 2.设备连接mqtt 3.微信小程序 备注 本文esp32用的是MicroPython固件&#xff0c;MQTT服务用的是巴法云。 本文参考巴法云官方教程&#xff1a;https://bemfa.blog.csdn.net/article/details/115282152 1.注册巴法云 注册登陆并新建一个topic&#xff…

SQLMesh隔离系统深度实践指南:动态模式映射与跨环境计算复用

在数据安全与开发效率的双重压力下&#xff0c;SQLMesh通过动态模式映射、跨环境计算复用和元数据隔离机制三大核心技术&#xff0c;完美解决了生产与非生产环境的数据壁垒问题。本文提供从环境配置到生产部署的完整实施框架&#xff0c;助您构建安全、高效、可扩展的数据工程体…

Spring Data详解:简化数据访问层的开发实践

1. 什么是Spring Data&#xff1f; Spring Data 是Spring生态中用于简化数据访问层&#xff08;DAO&#xff09;开发的核心模块&#xff0c;其目标是提供统一的编程模型&#xff0c;支持关系型数据库&#xff08;如MySQL&#xff09;、NoSQL&#xff08;如MongoDB&#xff09;…

15 nginx 中默认的 proxy_buffering 导致基于 http 的流式响应存在 buffer, 以 4kb 一批次返回

前言 这也是最近碰到的一个问题 直连 流式 http 服务, 发现 流式响应正常, 0.1 秒接收到一个响应 但是 经过 nginx 代理一层之后, 就发现了 类似于缓冲的效果, 1秒接收到 10个响应 最终 调试 发现是 nginx 的 proxy_buffering 配置引起的 然后 更新 proxy_buffering 为…

源超长视频生成模型:FramePack

FramePack 是一种下一帧&#xff08;下一帧部分&#xff09;预测神经网络结构&#xff0c;可以逐步生成视频。 FramePack 将输入上下文压缩为固定长度&#xff0c;使得生成工作量与视频长度无关。即使在笔记本电脑的 GPU 上&#xff0c;FramePack 也能处理大量帧&#xff0c;甚…

第6次课 贪心算法 A

向日葵朝着太阳转动&#xff0c;时刻追求自身成长的最大可能。 贪心策略在一轮轮的简单选择中&#xff0c;逐步导向最佳答案。 课堂学习 引入 贪心算法&#xff08;英语&#xff1a;greedy algorithm&#xff09;&#xff0c;是用计算机来模拟一个「贪心」的人做出决策的过程…

Windows使用SonarQube时启动脚本自动关闭

一、解决的问题 Windows使用SonarQube时启动脚本自动关闭&#xff0c;并发生报错&#xff1a; ERROR: Elasticsearch did not exit normally - check the logs at E:\Inori_Code\Year3\SE\sonarqube-25.2.0.102705\sonarqube-25.2.0.102705\logs\sonarqube.log ERROR: Elastic…

人机共跑,马拉松人型机器人同跑

马拉松比赛对人形机器人来说&#xff0c;是一场对硬件极限的测试&#xff0c;涉及机械、传感器、能源管理等多个方面。用户问的是硬件方面的考察和改进&#xff0c;这意味着我的回答需要聚焦于硬件性能&#xff0c;而不是算法或软件的优化。 对人形机器人硬件的考研 机械结构与…

Ubuntu Linux 中文输入法默认使用英文标点

先ubuntu从wayland切换到x11, sudo nano /etc/gdm3/custom.conf WaylandEnablefalse #取消注释 sudo systemctl restart gdm3 #使设置生效然后安装fcitx(是fcitx4版本)和 fcitx-googlepinyin, sudo apt install fcitx fcitx-googlepinyin 再sudo dpkg -i 安装百度输入法deb…

[论文阅读]ConfusedPilot: Confused Deputy Risks in RAG-based LLMs

ConfusedPilot: Confused Deputy Risks in RAG-based LLMs [2408.04870] ConfusedPilot: Confused Deputy Risks in RAG-based LLMs DEFCON AI Village 2024 文章是针对Copilot这样一个RAG服务提供平台的攻击 在企业环境中整合人工智能工具&#xff08;如 RAG&#xff09;会…

前端做模糊查询(含AI版)

文章目录 前言代码实现AI个人 总结 前言 因为table需要编辑&#xff0c;所以如果从后端拿数据&#xff0c;编辑后筛选数据就会丢失。这时候就需要前端一次性拿到所有数据进行过滤&#xff0c;数据进行浅拷贝&#xff0c;以便过滤后的数据修改之后&#xff0c;同步修改总数居&a…

Mujoco xml < sensor>

< sensor> jointposjointveljointactuatorfrcframequatgyroaccelerometerframeposframelinveltouchobjtype"site" objname"imu" 和site"imu"的区别python中与sensor有关的写法传感器名字索引第几个idid索引传感器名字传感器数量sensor中的…

Python爬虫从入门到实战详细版教程

Python爬虫从入门到实战详细版教程 文章目录 Python爬虫从入门到实战详细版教程书籍大纲与内容概览第一部分:爬虫基础与核心技术1. 第1章:[爬虫概述](https://blog.csdn.net/qq_37360300/article/details/147431708?spm=1001.2014.3001.5501)2. 第2章:HTTP协议与Requests库…