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

一套万能的异步处理方案!(珍藏版)

前言良好的系统设计必须要做到开闭原则随着业务的不断迭代更新核心代码也会被不断改动出错的概率也会大大增加。但是大部分增加的功能都是在扩展原有的功能既要保证性能又要保证质量我们往往都会使用异步线程池来处理然而却增加了很多不确定性因素。由此我设计了一套通用的异步处理SDK可以很轻松的实现各种异步处理目的通过异步处理不仅能够保证方法能够得到有效的执行而且不影响主流程更重要的是各种兜底方法保证数据不丢失从而达到最终一致性优点无侵入设计独立数据库独立定时任务独立消息队列独立人工执行界面(统一登录认证)使用spring事务事件机制即使异步策略解析失败也不会影响业务如果你的方法正在运行事务会等事务提交后或回滚后再处理事件就算事务提交了异步策略解析失败了我们还有兜底方案执行除非数据库有问题消息队列有问题方法有bug原理容器初始化bean完成后遍历所有方法把有AsyncExec注解的方法缓存起来方法运行时通过AOP切面发布事件事务事件监听处理异步执行策略TransactionalEventListener(fallbackExecution true, phase TransactionPhase.AFTER_COMPLETION)fallbackExecutiontrue没有事务正在运行依然处理事件TransactionPhase.AFTER_COMPLETION事务提交后和事务回滚后都处理事件组件kafka 消息队列xxl job 定时任务mysql 数据库spring 切面vue 界面设计模式策略模板方法动态代理流程图图片数据库脚本CREATE TABLE async_scene ( id bigint NOT NULL AUTO_INCREMENT COMMENT 主键ID, application_name varchar(100) NOT NULL DEFAULT COMMENT 应用名称, method_sign varchar(50) NOT NULL DEFAULT COMMENT 方法签名, scene_name varchar(200) NOT NULL DEFAULT COMMENT 业务场景描述, async_type varchar(50) NOT NULL DEFAULT COMMENT 异步策略类型, queue_name varchar(200) NOT NULL DEFAULT COMMENT 队列名称, theme_value varchar(100) NOT NULL DEFAULT COMMENT 消费主题, exec_count int NOT NULL DEFAULT 0 COMMENT 失败重试次数, exec_deleted int NOT NULL DEFAULT 0 COMMENT 执行后是否删除, async_version varchar(50) NOT NULL DEFAULT COMMENT 组件版本号, create_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, update_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 更新时间, cdc_crt_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 记录新增时间, cdc_upd_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT 记录修改时间, PRIMARY KEY (id) USING BTREE, UNIQUE KEY uk_application_sign (application_name,method_sign) USING BTREE, KEY idx_cdc_upd_time (cdc_upd_time) ) ENGINEInnoDB COMMENT异步场景表; CREATE TABLE async_req ( id bigint NOT NULL AUTO_INCREMENT COMMENT 主键ID, application_name varchar(100) NOT NULL DEFAULT COMMENT 应用名称, sign varchar(50) NOT NULL DEFAULT COMMENT 方法签名, class_name varchar(200) NOT NULL DEFAULT COMMENT 全路径类名称, method_name varchar(100) NOT NULL DEFAULT COMMENT 方法名称, async_type varchar(50) NOT NULL DEFAULT COMMENT 异步策略类型, exec_status tinyint NOT NULL DEFAULT 0 COMMENT 执行状态 0初始化 1执行失败 2执行成功, exec_count int NOT NULL DEFAULT 0 COMMENT 执行次数, param_json longtext COMMENT 请求参数, remark varchar(200) NOT NULL DEFAULT COMMENT 业务描述, create_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, update_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 更新时间, PRIMARY KEY (id) USING BTREE, KEY idx_applocation_name (application_name) USING BTREE, KEY idx_exec_status (exec_status) USING BTREE ) ENGINEInnoDB DEFAULT CHARSETutf8mb4 COMMENT异步处理请求; CREATE TABLE async_log ( id bigint NOT NULL AUTO_INCREMENT COMMENT 主键ID, async_id bigint NOT NULL DEFAULT 0 COMMENT 异步请求ID, error_data longtext COMMENT 执行错误信息, create_time datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT 创建时间, PRIMARY KEY (id) USING BTREE, KEY idx_async_id (async_id) USING BTREE ) ENGINEInnoDB DEFAULT CHARSETutf8mb4 COMMENT异步处理日志;异步策略图片安全级别图片执行状态图片流程图图片图片图片apollo 配置# 开关默认关闭 async.enabledtrue # 应用名称 spring.application.namexxx # 数据源 druid spring.datasource.driver-class-namecom.mysql.jdbc.Driver spring.datasource.urljdbc:mysql://127.0.0.1:3306/fc_async?useUnicodetruecharacterEncodingutf-8zeroDateTimeBehaviorconvertToNulluseSSLfalseallowMultiQueriestruerewriteBatchedStatementstrue spring.datasource.usernameuser spring.datasource.passwordxxxx spring.datasource.filtersconfig spring.datasource.connectionPropertiesconfig.decrypttrue;config.decrypt.keyyyy #静态地址 spring.resources.add-mappingstrue spring.resources.static-locationsclasspath:/static/ # 以下配置都有默认值 # 核心线程数 async.executor.thread.corePoolSize10 # 最大线程数 async.executor.thread.maxPoolSize50 # 队列容量 async.executor.thread.queueCapacity10000 # 活跃时间 async.executor.thread.keepAliveSeconds600 # 执行成功是否删除记录默认删除 async.exec.deletedtrue # 自定义队列名称前缀默认应用名称 async.topic${spring.application.name} # 重试执行次数默认5次 async.exec.count5 # 重试最大查询数量 async.retry.limit100 # 补偿最大查询数量 async.comp.limit100 # 登录拦截默认false async.loginfalse用法1异步开关scm.async.enabledtrue2在需要异步执行的方法加注解 必须是spring代理方法AsyncExec(type AsyncExecEnum.SAVE_ASYNC, remark 数据字典)3人工处理地址http://localhost:8004/async/index.html注意1、应用名称spring.application.name2、队列名称${async.topic:${spring.application.name}}_async_queue3、自己业务要做幂等4、一个应用公用一个队列自产自消5、定时任务异步重试定时任务2分钟重试一次可配置重试次数异步补偿定时任务一小时补偿一次创建时间在一小时之前的效果展示图片图片代码地址https://github.com/xiongyanokok/fc-async

相关文章:

一套万能的异步处理方案!(珍藏版)

前言 良好的系统设计必须要做到开闭原则,随着业务的不断迭代更新,核心代码也会被不断改动,出错的概率也会大大增加。但是大部分增加的功能都是在扩展原有的功能,既要保证性能又要保证质量,我们往往都会使用异步线程池…...

SpringBoot+Tess4j:轻松实现OCR功能

一、引言二、功能演示三、功能实现1. 描述2. 编码实现四、源码五、结束语一、引言你是否曾遇到过这样的情况:看到一段有用的文本,想要快速复制下来,却只能眼巴巴地盯着屏幕,手动输入?其实,Java 也可以轻松实…...

手把手教你学Simulink——基于Simulink的无差拍控制三相整流器高精度电流跟踪

目录 手把手教你学Simulink ——基于Simulink的无差拍控制三相整流器高精度电流跟踪 一、问题背景 二、系统建模与控制原理 1. 三相整流器拓扑 2. dq 轴数学模型(同步旋转坐标系) 3. 无差拍控制律推导 三、整体控制架构 四、Simulink 建模步骤 第一步:搭建三相整流…...

FreeRtos——24、STM32中断处理体系及软件定时器按键消抖

第一节:STM32中断处理体系结构1.中断处理路径:2.NVIC中断控制器的中断优先级:2.1 中断号:在NVIC中对于硬件产生的任何一个中断都分配了一个中断号,中断号是一个唯一的标识符,用于识别每个外设设备的中断。NVIC使用中断号来配置中断…...

手把手教你学Simulink——基于Simulink的模型预测控制(MPC)PFC整流器快速动态响应

目录 手把手教你学Simulink ——基于Simulink的模型预测控制(MPC)PFC整流器快速动态响应 一、问题背景 二、系统建模与控制目标 1. 单相 Boost PFC 拓扑 2. 动态方程(αβ 静止坐标系) 3. 控制目标 三、有限控制集 MPC(FCS-MPC)设计 1. 预测模型(离散化) 2. 代…...

ViT图像分类-中文-日常物品完整指南:4090D单卡环境配置与中文类别映射说明

ViT图像分类-中文-日常物品完整指南:4090D单卡环境配置与中文类别映射说明 想试试用AI模型来识别你手机里的照片吗?比如,拍一张桌上的水杯、键盘或者零食,让模型告诉你它是什么。今天要介绍的这个工具,就能帮你轻松实…...

微信小程序语音交互实战:长按录制与点击播放的完整实现方案

1. 微信小程序语音交互功能概述 语音交互已经成为现代移动应用不可或缺的功能之一。在微信小程序中实现语音录制与播放,能够极大提升用户体验,特别适合社交、教育、工具类小程序。我最近在一个社交类小程序项目中实现了完整的语音交互模块,踩…...

用STM32F103C8T6和F9P模组DIY一台RTK无人车:从蓝牙遥控到自主导航的保姆级教程

用STM32F103C8T6和F9P模组打造高精度RTK无人车:从零构建到自主导航全流程解析 在创客圈子里,能够自主导航的智能小车一直是热门项目。但传统基于普通GPS的方案定位精度往往在米级徘徊,难以实现真正的精准控制。而将RTK(实时动态定…...

终极Cursor Pro解锁指南:免费体验AI编程助手的完整解决方案

终极Cursor Pro解锁指南:免费体验AI编程助手的完整解决方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached you…...

小白友好!Stable Diffusion v1.5单卡运行多个服务,详细步骤+避坑指南

小白友好!Stable Diffusion v1.5单卡运行多个服务,详细步骤避坑指南 1. 为什么需要单卡多服务? 很多刚接触Stable Diffusion的朋友都会遇到这样的困扰:团队里几个人共用一台服务器,但GPU卡只有一张。一个人用的时候还…...

ai辅助硬件设计:让快马智能解析并生成db9接口与mcu连接的完整原理图与代码

在硬件开发中,DB9接口的设计与连接是个常见但容易出错的环节。最近我在一个嵌入式项目里需要实现STM32与DB9接口的RS-232通信,发现传统设计流程存在几个痛点: 引脚定义容易混淆 DB9公头和母头的引脚定义是相反的,比如母头的2号引脚…...

VoxCPM-1.5-WEBUI问题解决:部署常见错误与一键启动脚本详解

VoxCPM-1.5-WEBUI问题解决:部署常见错误与一键启动脚本详解 1. 快速入门指南 1.1 镜像部署准备 在开始使用VoxCPM-1.5-WEBUI之前,您需要确保具备以下条件: 支持CUDA的NVIDIA显卡(建议RTX 3060及以上)至少16GB系统内…...

深入解析cufftPlanMany:从参数配置到高效FFT实现

1. 为什么需要cufftPlanMany? 第一次接触CUDA FFT时,很多人都是从cufftPlan1d、cufftPlan2d这些基础接口开始的。但当你真正处理实际工程问题时,会发现这些简单接口远远不够用。比如要处理批量信号、非连续内存数据、子区域FFT计算等场景时&a…...

告别手动处理:用快马AI一键生成你的专属批量链接效率工具

最近在整理项目文档时,经常需要处理大量杂乱无章的链接。手动一个个检查、格式化这些链接不仅耗时耗力,还容易出错。于是我开始寻找更高效的解决方案,最终在InsCode(快马)平台上快速实现了一个批量链接处理工具,整个过程比想象中简…...

QMCDecode:让音乐自由播放的开源格式转换工具

QMCDecode:让音乐自由播放的开源格式转换工具 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默认转换结果存…...

Gemma-3-270m内网穿透部署方案

Gemma-3-270m内网穿透部署方案:安全打通企业AI服务 想象一下这个场景:你们公司的研发团队刚刚在内部服务器上部署了轻量高效的Gemma-3-270m模型,准备用它来优化客服工单分类、自动生成产品文档。模型跑起来了,效果也不错&#xf…...

4个维度解析Lenovo Legion Toolkit:游戏本性能管理的轻量革命

4个维度解析Lenovo Legion Toolkit:游戏本性能管理的轻量革命 【免费下载链接】LenovoLegionToolkit Lightweight Lenovo Vantage and Hotkeys replacement for Lenovo Legion laptops. 项目地址: https://gitcode.com/gh_mirrors/le/LenovoLegionToolkit 1.…...

LFM2.5-1.2B-Thinking-GGUF算法解析应用:图解经典算法与复杂度分析

LFM2.5-1.2B-Thinking-GGUF算法解析应用:图解经典算法与复杂度分析 1. 算法可视化教学新范式 算法学习一直是计算机科学教育中的难点。传统的教科书讲解方式往往让初学者感到抽象难懂,而LFM2.5-1.2B-Thinking-GGUF模型为算法教学带来了全新的可视化解决…...

如何用开源工具实现3D打印钥匙自由?从参数测量到模型生成的实践路径

如何用开源工具实现3D打印钥匙自由?从参数测量到模型生成的实践路径 【免费下载链接】keygen OpenSCAD tools for generating physical keys 项目地址: https://gitcode.com/gh_mirrors/ke/keygen 在数字化制造蓬勃发展的今天,3D打印技术正逐步走…...

龙虾agent-browser获得chromium包问题

小龙虾非常火爆,在装agent-browser的时候,普通人往往被chromium的安装堵死了。网上的跨域安装方法一大堆,包括用镜像站点,国内所有的镜像站点都不行。但是真正能走通的,我到最后也没有试出来。最后只能自己想出一种手动…...

Obsidian图像转换:提升笔记效率的格式优化解决方案

Obsidian图像转换:提升笔记效率的格式优化解决方案 【免费下载链接】obsidian-image-converter ⚡️ Convert, compress, resize, annotate, markup, draw, crop, rotate, flip, align images directly in Obsidian. Drag-resize, rename with variables, batch pro…...

Realistic Vision V5.1效果展示:这些惊艳的人像作品都是AI生成的

Realistic Vision V5.1效果展示:这些惊艳的人像作品都是AI生成的 1. 当AI画师遇上专业摄影师 你有没有见过这样的AI生成人像?皮肤纹理清晰到能看见毛细血管,发丝在阳光下呈现自然的半透明质感,眼神光的位置精准符合物理反射规律…...

Path of Building PoE2:零基础掌握流放之路2角色规划工具实战指南

Path of Building PoE2:零基础掌握流放之路2角色规划工具实战指南 【免费下载链接】PathOfBuilding-PoE2 项目地址: https://gitcode.com/GitHub_Trending/pa/PathOfBuilding-PoE2 你是否曾遇到这样的困境:花费数小时规划的角色build&#xff0c…...

一站式屏幕神器eSearch:如何5分钟打造你的智能工作流?

一站式屏幕神器eSearch:如何5分钟打造你的智能工作流? 【免费下载链接】eSearch 截屏 离线OCR 搜索翻译 以图搜图 贴图 录屏 万向滚动截屏 屏幕翻译 Screenshot Offline OCR Search Translate Search for picture Paste the picture on the screen Scree…...

【大英赛】2009-2026年大英赛ABCD类历年真题、样卷、听力音频及答案PDF电子版

2026年大英赛将于4月12日9:00—11:00举行,开始倒计时啦!小编整理了最新的2009-2026年大学生英语竞赛(大英赛NECCS)ABCD类历年真题、样卷、听力音频及答案解析,PDF电子版,可下载打印! 资料下载&a…...

不止于超市:用QGIS缓冲区+叠置分析,为你的奶茶店、自习室找个好位置

从奶茶店到自习室:QGIS空间分析赋能小微商业选址决策 走在街头,你是否好奇为什么某些奶茶店总是门庭若市,而几步之隔的同类店铺却冷冷清清?商业选址从来不是简单的"地段好"三个字能概括的。对于资金有限的小微创业者来说…...

鸿蒙应用开发实战:手把手教你封装一个可复用的音乐播放器管理类(ArkTS版)

鸿蒙应用开发实战:构建高可复用的音乐播放器管理类(ArkTS版) 在鸿蒙应用开发中,音频播放功能是许多应用的核心需求。本文将深入探讨如何设计一个健壮、可复用的音乐播放器管理类,采用ArkTS语言实现,帮助开发…...

讲透RenderTarget · 第一章:RenderTarget 是什么

**欢迎新朋友点赞、关注、收藏三连。第一章:RenderTarget 是什么一句话概括: RenderTarget 就是 GPU 的"画布"——不一定画在屏幕上,可以画在任何一块显存里。⏱ 30 秒概览RenderTarget(RT) GPU 可以写入像素…...

Windows自定义部署神器:从零开始的安装介质制作指南

Windows自定义部署神器:从零开始的安装介质制作指南 【免费下载链接】MediaCreationTool.bat Universal MCT wrapper script for all Windows 10/11 versions from 1507 to 21H2! 项目地址: https://gitcode.com/gh_mirrors/me/MediaCreationTool.bat 你是否…...

从idea ai插件到在线原型:用快马平台快速构建你的智能代码生成器

最近在开发中频繁使用IDEA的AI插件辅助编码,发现这类工具能大幅减少重复劳动。但插件功能往往局限于当前IDE环境,于是萌生了一个想法:能否把这种智能生成能力搬到线上,做成一个轻量级的Web工具?经过在InsCode(快马)平台…...