当前位置: 首页 > article >正文

Java 分布式高并发重试方案及实现

文章目录

  • Java 分布式高并发重试方案及实现
    • 一、重试机制的背景和意义
    • 二、基于 Spring Boot 的重试方案实现
      • 1. 使用 Spring Retry 实现重试机制
        • 添加依赖
        • 开启重试功能
        • 定义重试逻辑
        • 使用重试服务
      • 2. 使用 Fast-Retry 实现高性能重试
        • 引入依赖
        • 编程式重试
        • 注解式重试
    • 三、重试机制的注意事项
    • 四、总结

Java 分布式高并发重试方案及实现

在分布式系统中,高并发场景下接口调用的稳定性至关重要。为了应对接口调用失败的情况,提高系统的容错性和可靠性,重试机制成为一种常见的解决方案。本文将介绍 Java 分布式高并发重试方案,并基于 Spring Boot 提供具体的实现方法。

一、重试机制的背景和意义

在分布式系统中,服务之间的调用可能会因为网络波动、超时、服务繁忙等原因导致失败。如果不对这些失败的调用进行处理,可能会导致业务流程中断,影响用户体验。通过对接口调用进行重试,可以在一定程度上提高调用的成功率,保证业务的连续性。

二、基于 Spring Boot 的重试方案实现

1. 使用 Spring Retry 实现重试机制

Spring Retry 是 Spring 提供的一个用于实现重试功能的库,支持多种重试策略和回退机制。

添加依赖

在项目的 pom.xml 文件中,添加 Spring Retry 的依赖:

<dependency><groupId>org.springframework.retry</groupId><artifactId>spring-retry</artifactId><version>1.3.1</version>
</dependency>
<dependency><groupId>org.springframework.retry</groupId><artifactId>spring-retry-annotations</artifactId><version>1.3.1</version>
</dependency>
开启重试功能

在 Spring Boot 应用的主类或配置类中添加 @EnableRetry 注解:

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.retry.annotation.EnableRetry;@SpringBootApplication
@EnableRetry
public class RetryApplication {public static void main(String[] args) {SpringApplication.run(RetryApplication.class, args);}
}
定义重试逻辑

创建一个服务类,并在需要重试的方法上添加 @Retryable 注解:

import org.springframework.retry.annotation.Backoff;
import org.springframework.retry.annotation.Retryable;
import org.springframework.stereotype.Service;@Service
public class RetryService {@Retryable(value = { RuntimeException.class }, maxAttempts = 3, backoff = @Backoff(delay = 2000))public void performOperation() {System.out.println("Performing operation...");if (Math.random() > 0.5) {throw new RuntimeException("Operation failed");}System.out.println("Operation succeeded");}@Recoverpublic void recover(RuntimeException e) {System.out.println("Operation failed after retries: " + e.getMessage());}
}

在上述代码中,@Retryable 注解标记了 performOperation 方法,指定了当发生 RuntimeException 异常时进行重试。maxAttempts 指定最大重试次数,backoff 指定了重试间隔的初始延迟。

使用重试服务

在控制器中调用重试服务的方法:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class RetryController {@Autowiredprivate RetryService retryService;@GetMapping("/retry")public String retryOperation() {retryService.performOperation();return "Operation attempted";}
}

2. 使用 Fast-Retry 实现高性能重试

Fast-Retry 是一个高性能的百万级任务重试框架,适用于分布式高并发场景。

引入依赖

在项目的 pom.xml 文件中,添加 Fast-Retry 的依赖:

<dependency><groupId>io.github.burukeyou</groupId><artifactId>fast-retry-all</artifactId><version>0.2.0</version>
</dependency>
编程式重试

使用重试队列实现重试逻辑:

import io.github.burukeyou.fastretry.annotation.EnableFastRetry;
import io.github.burukeyou.fastretry.core.RetryQueue;
import io.github.burukeyou.fastretry.task.RetryTask;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;@RestController
@EnableFastRetry
public class FastRetryController {@GetMapping("/fastRetry")public String fastRetry() {ExecutorService executorService = Executors.newFixedThreadPool(8);RetryQueue queue = new FastRetryQueue(executorService);RetryTask<String> task = new RetryTask<String>() {int result = 0;@Overridepublic long waitRetryTime() {return 2000;}@Overridepublic boolean retry() {return ++result < 5;}@Overridepublic String getResult() {return result + "";}};CompletableFuture<String> future = queue.submit(task);try {log.info("任务结束 结果:{}", future.get());} catch (Exception e) {e.printStackTrace();}return "Task submitted";}
}
注解式重试

使用注解 @FastRetry 实现重试逻辑:

import io.github.burukeyou.fastretry.annotation.EnableFastRetry;
import io.github.burukeyou.fastretry.annotation.FastRetry;
import io.github.burukeyou.fastretry.annotation.RetryWait;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.concurrent.CompletableFuture;@RestController
@EnableFastRetry
public class AnnotationRetryController {@GetMapping("/annotationRetry")@FastRetry(retryWait = @RetryWait(delay = 2))public CompletableFuture<String> annotationRetry() {return CompletableFuture.completedFuture("success");}
}

三、重试机制的注意事项

在实现重试机制时,需要注意以下几点:

  1. 避免无限重试:设置合理的重试次数,避免因无限重试导致系统资源耗尽。
  2. 控制重试间隔:设置适当的重试间隔,避免对服务造成过大压力。
  3. 考虑幂等性:对于非幂等性的接口,需要谨慎处理重试逻辑,避免因重复调用导致数据不一致。
  4. 记录日志和监控:对接口重试的情况进行记录和监控,方便排查问题和分析系统性能。

四、总结

在分布式高并发场景中,重试机制是提高系统容错性和可靠性的重要手段。本文介绍了基于 Spring Boot 的两种重试方案:使用 Spring Retry 和 Fast-Retry。通过合理的配置和使用,可以有效地提高接口调用的成功率,保证系统的稳定运行。在实际应用中,需要根据业务需求和系统特性选择合适的重试策略,并注意重试机制的潜在问题,以实现高效、可靠的重试功能。

相关文章:

Java 分布式高并发重试方案及实现

文章目录 Java 分布式高并发重试方案及实现一、重试机制的背景和意义二、基于 Spring Boot 的重试方案实现1. 使用 Spring Retry 实现重试机制添加依赖开启重试功能定义重试逻辑使用重试服务 2. 使用 Fast-Retry 实现高性能重试引入依赖编程式重试注解式重试 三、重试机制的注意…...

Spring Boot 集成 Quartz 实现定时任务(Cron 表达式示例)

Spring Boot 集成 Quartz 实现定时任务&#xff08;Cron 表达式示例&#xff09; 前言1. 添加 Quartz 依赖2. 创建 Quartz 任务3. 配置 Quartz 任务调度4. 启动 Spring Boot 观察定时任务执行5. Quartz Cron 表达式详解6. 结论 前言 在 Spring Boot 项目中&#xff0c;我们经常…...

关于“碰一碰发视频”系统的技术开发文档框架

以下是关于“碰一碰发视频”系统的技术开发文档框架&#xff0c;涵盖核心功能、技术选型、开发流程和关键模块设计&#xff0c;帮助您快速搭建一站式解决方案 --- 随着短视频平台的兴起&#xff0c;用户的创作与分享需求日益增长。而如何让视频分享更加便捷、有趣&#xff0c…...

vue3之写一个aichat---已聊天组件部分功能

渲染聊天数据 这个不必多说&#xff0c;直接从stores/chat中取出聊天列表数据渲染就好&#xff0c;因为前面添加的消息都是按照用户消息、AI助手消息这样添加的&#xff0c;效果如图 但是需要注意每条助手消息的状态&#xff0c;需要根据状态显示不同的图标或不显示图标&…...

ffmpeg+ubuntu编译库(完整版本)

个人使用环境: ubuntu desktop 16.04 + ffmpeg 4.2.1创建目录在home目录下创建 ffmpeg_sources:用于下载源文件 ffmpeg_build: 存储编译后的库文件 bin:存储二进制文件(ffmpeg,ffplay,ffprobe,X264,X265等) mkdir ffmpeg_sources ffmpeg_build bin安装依赖 先执行…...

基于STC89C51的太阳自动跟踪系统的设计与实现—单片机控制步进电机实现太阳跟踪控制(仿真+程序+原理图+PCB+文档)

摘 要 随着我国经济的飞速发展&#xff0c;促使各种能源使用入不敷出&#xff0c;尤其是最主要的能源&#xff0c;煤炭石油资源不断消耗与短缺&#xff0c;因此人类寻找其他替代能源的脚步正在加快。而太阳能则具有无污染﹑可再生﹑储量大等优点&#xff0c;且分布范围广&…...

第五: redis 安装 / find 查找目录

redis 安装的 两种方式&#xff1a; mac上安装redis的两种方法_如何在mac上安装redis-CSDN博客 首先可以先看一下brew的常用命令如下&#xff1a; brew search ** //查找某个软件包 brew list //列出已经安装的软件的包 brew install ** //安装某个软件包,默认安装的是…...

c++--vector

1.定义vector vector的定义分为四种 (1)vector() ——————无参构造 (2)vector(size_t n,const value_type& val value_type()) ——————构造并初始化n个val (3)vector(const vector& v1) ———————拷贝构造 (4)vector(inputiterator first,inpu…...

Springboot 项目如何输出优雅的日志

我们先看效果图&#xff1a; 我个人比较喜欢这种格式的日志输出&#xff0c;对其完整&#xff1b; 这种格式其实就是默认的&#xff0c;不需要大家配置任何的 logback-spring 文件和xml中配置日志level 没有做任何多余的配置&#xff1b;...

Linux——进程(5)进程地址空间

先看一个程序和现象 预期现象是&#xff0c;子进程和父进程相互独立&#xff0c;子进程的gval是100&#xff0c;101&#xff0c;102....而父进程一直都是100. 结果我们并不意外&#xff0c;只是我们发现&#xff0c;父子进程的gval的地址是一样的&#xff0c;这有点颠覆我们的认…...

代码随想录_动态规划

代码随想录 动态规划 509.斐波那契数 509. 斐波那契数 斐波那契数 &#xff08;通常用 F(n) 表示&#xff09;形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始&#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0&#xff0c;F(1) 1 F(n…...

c库、POSIX库、C++库、boost库之间的区别和联系

文章目录 一、区别1. 定义和来源2. 功能范围3. 可移植性4. 语言支持5. 维护和更新 二、联系1. 相互补充2. 部分功能重叠3. 共同促进编程发展4. 代码兼容性 三、总结 一、区别 1. 定义和来源 C 库函数&#xff1a;由 ANSI C 和 ISO C 标准定义&#xff0c;是 C 语言编程的基础…...

Maven常见问题汇总

Maven刷新,本地仓库无法更新 现象 This failure was cached in the local repository and resolution is not reattempted until the update interval of aliyunmaven has elapsed or updates are forced原因 因为上一次尝试下载&#xff0c;发现对应的仓库没有这个maven配置…...

星越L_陡坡缓降使用讲解

目录 1.陡坡缓降 1.陡坡缓降 中控屏下滑-点击陡坡缓降功能 35km/h以下时生效。35km/h-60km/h该功能暂停 60km/h以上该功能关闭...

XSS跨站脚本攻击漏洞(Cross Site Scripting)

前提概要 本文章主要用于分享XSS跨站脚本攻击漏洞基础学习&#xff0c;以下是对XSS跨站脚本攻击漏洞的一些个人解析&#xff0c;请大家结合参考其他文章中的相关信息进行归纳和补充。 XSS跨站脚本攻击漏洞描述 跨站脚本攻击&#xff08;XSS&#xff09;漏洞是一种常见且危害较…...

html5基于Canvas的经典打砖块游戏开发实践

基于Canvas的经典打砖块游戏开发实践 这里写目录标题 基于Canvas的经典打砖块游戏开发实践项目介绍技术栈核心功能实现1. 游戏初始化2. 游戏对象设计3. 碰撞检测系统4. 动画系统5. 用户界面设计 性能优化1. 渲染优化2. 内存管理 项目亮点技术难点突破项目总结 项目介绍 在这个…...

企业信息化的“双螺旋”——IT治理和数据治理

企业信息化的“双螺旋”——IT治理和数据治理 一、核心定义二、关键差异三、内在联系四、实践挑战与融合路径五、行业案例参考六、结论数据治理(Data Governance)和IT治理(IT Governance)是现代企业数字化转型中的关键概念,二者既有紧密关联又各有侧重。以下从定义、核心内…...

设计模式之工厂模式的优缺点

工厂模式是一种创建对象的设计模式&#xff0c;它将对象的创建和使用分离。以下是工厂模式的优缺点&#xff1a; 优点 - 解耦对象的创建和使用&#xff1a;使得代码的依赖关系更加清晰&#xff0c;使用者不需要了解对象的具体创建过程&#xff0c;只需要关心如何使用对象&a…...

CCBCISCN复盘

AWDP – ccfrum 自己搭了一下环境, 复现一下这道题目, 之前比赛的时候完全没想到这个漏洞要怎么打, 修也不知道要怎么修, 就仅仅是对用户名的账号和密码进行了一下过滤, 完全没起到作用, 唉, 实在太菜 如果想要尝试复现的话可以尝试拉取这个镜像, 我打完之后就直接把这个容器给…...

糊涂人寄信——递推

思路分析&#xff1a;当有n封信&#xff0c;n个信封时。第k封信没有装在第k个信封里&#xff08;k从1~n&#xff09;&#xff0c;就算所有的信封都装错了。我们可以得知的是&#xff0c;当有1封信,时&#xff0c;装错类别数为0。当有两封信时&#xff0c;装错类别为1。 当有三…...

OpenHarmony子系统开发 - 电源管理(一)

OpenHarmony子系统开发 - 电源管理&#xff08;一&#xff09; 一、电源模式定制开发指导 概述 简介 OpenHarmony默认提供了电源模式&#xff08;如正常模式、性能模式、省电模式、超级省电模式&#xff09;的特性。但由于不同产品的部件存在差异&#xff0c;导致在同样场景…...

使用 OpenCV 拼接进行图像处理对比:以形态学操作为例

图像处理在计算机视觉中起着至关重要的作用&#xff0c;而 OpenCV 作为一个强大的图像处理库&#xff0c;提供了丰富的函数来实现各类图像处理任务。形态学操作&#xff08;Morphological Operations&#xff09;是其中常用的技术&#xff0c;尤其适用于二值图像的处理。常见的…...

数据库的左连接,右连接,全外连接,自连接,内连接的区别

从语法层面上看&#xff0c; 全外连接full outer join 左连接是left outer join 右连接是right outer join 内连接是inner join 自连接是自身表与自身表进行的左右连接&#xff0c;需要注意的是并没有左内连接和右内连接。 左外连接 select * from A left outer join B …...

Nexus L2 L3基本配置

接口基本配置 N7K上所有端口默认处于shutdown状态; N5K上所有端口默认处于no shutdown状态(所有端口都是switchport) 默认所有接口都是三层route模式, 只有当线卡不支持三层的时候, 接口才会处于二层switchport模式 show run all | in “system default” 创建SVI口需要提前打…...

OpenHarmony 入门——ArkUI 跨页面数据同步和页面级UI状态存储LocalStorage小结(二)

文章大纲 引言一、在代码逻辑使用LocalStorage二、从UI内部使用LocalStorage三、LocalStorageProp和LocalStorage单向同步四、LocalStorageLink和LocalStorage双向同步五、兄弟组件之间同步状态变量七、将LocalStorage实例从UIAbility共享到一个或多个视图 引言 前面一篇文章主…...

Python数据可视化实战:从基础图表到高级分析

Python数据可视化实战&#xff1a;从基础图表到高级分析 数据可视化是数据分析的重要环节&#xff0c;通过直观的图表可以快速洞察数据规律。本文将通过5个实际案例&#xff0c;手把手教你使用Python的Matplotlib库完成各类数据可视化任务&#xff0c;涵盖条形图、堆积面积图、…...

在 Elasticsearch 中扩展后期交互模型 - 第 2 部分 - 8.18

作者&#xff1a;来自 Elastic Peter Straer 及 Benjamin Trent 本文探讨了如何优化后期交互向量&#xff0c;以适应大规模生产工作负载&#xff0c;例如减少磁盘空间占用和提高计算效率。 在之前关于 ColPali 的博客中&#xff0c;我们探讨了如何使用 Elasticsearch 创建视觉搜…...

蓝桥每日打卡--区间移位

#蓝桥#JAVA#区间移位 题目描述 数轴上有n个闭区间&#xff1a;D1,⋯Dn。 其中区间Di用一对整数[ai,bi]来描述&#xff0c;满足 ai≤bi。 已知这些区间的长度之和至少有。 所以&#xff0c;通过适当的移动这些区间&#xff0c;你总可以使得他们的"并"覆盖 [0,],也…...

CUDAOpenCV 基于Hessian矩阵计算特征值

文章目录 一、简介二、实现代码三、实现效果一、简介 基于之前的博客:CUDA&OpenCV Hessain矩阵计算,我们可以计算出每个像素的特征值: 二、实现代码 ComputeHessainMatrix.cuh #ifndef HESSAIN_GPU_CUH #...

基于CAMEL 的Workforce 实现多智能体协同工作系统

文章目录 一、workforce 简介1.架构设计2.通信机制 二、workforce 工作流程图示例1.用户角色2.工作流程 三、workforce 中重要函数说明1.__init__函数2.add_single_agent_worker 函数3.add_role_playing_worker 函数4.add_workforce 函数 四、基于workforce实现多智能体协调&am…...