news 2026/4/16 10:16:26

15.2 太牛了!任务超时控制和重试策略竟然还能这样实现?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
15.2 太牛了!任务超时控制和重试策略竟然还能这样实现?

15.2 太牛了!任务超时控制和重试策略竟然还能这样实现?

在分布式任务调度系统中,任务超时控制和重试策略是确保系统稳定性和任务可靠执行的重要机制。今天我们将深入探讨如何实现这些关键功能。

任务超时控制机制

任务超时控制是防止任务执行时间过长而阻塞系统资源的重要手段。我们需要实现精确的超时检测和优雅的超时中断机制。

packagetimeoutimport("context""fmt""sync""time")// TimeoutManager 超时管理器typeTimeoutManagerstruct{tasksmap[string]*TaskTimeoutInfo mu sync.RWMutex stopChchanstruct{}}// TaskTimeoutInfo 任务超时信息typeTaskTimeoutInfostruct{TaskIDstringDeadline time.Time Timeout time.Duration CancelFunc context.CancelFunc Callback TimeoutCallback Status TimeoutStatus}// TimeoutStatus 超时状态typeTimeoutStatusintconst(TimeoutStatusPending TimeoutStatus=iotaTimeoutStatusRunning TimeoutStatusTimeout TimeoutStatusCompleted)// TimeoutCallback 超时回调函数typeTimeoutCallbackfunc(taskIDstring)error// NewTimeoutManager 创建超时管理器funcNewTimeoutManager()*TimeoutManager{tm:=&TimeoutManager{tasks:make(map[string]*TaskTimeoutInfo),stopCh:make(chanstruct{}),}// 启动超时检查协程gotm.run()returntm}// AddTask 添加任务超时监控func(tm*TimeoutManager)AddTask(taskIDstring,timeout time.Duration,callback TimeoutCallback)error{tm.mu.Lock()defertm.mu.Unlock()// 检查任务是否已存在if_,exists:=tm.tasks[taskID];exists{returnfmt.Errorf("task %s already exists",taskID)}// 创建上下文和取消函数ctx,cancel:=context.WithTimeout(context.Background(),timeout)// 创建任务超时信息taskInfo:=&TaskTimeoutInfo{TaskID:taskID,Deadline:time.Now().Add(timeout),Timeout:timeout,CancelFunc:cancel,Callback:callback,Status:TimeoutStatusPending,}tm.tasks[taskID]=taskInforeturnnil}// StartTask 开始任务超时监控func(tm*TimeoutManager)StartTask(taskIDstring)error{tm.mu.Lock()defertm.mu.Unlock()taskInfo,exists:=tm.tasks[taskID]if!exists{returnfmt.Errorf("task %s not found",taskID)}taskInfo.Status=TimeoutStatusRunning taskInfo.Deadline=time.Now().Add(taskInfo.Timeout)returnnil}// CompleteTask 完成任务func(tm*TimeoutManager)CompleteTask(taskIDstring)error{tm.mu.Lock()defertm.mu.Unlock()taskInfo,exists:=tm.tasks[taskID]if!exists{returnfmt.Errorf("task %s not found",taskID)}// 取消上下文iftaskInfo.CancelFunc!=nil{taskInfo.CancelFunc()}taskInfo.Status=TimeoutStatusCompleted// 从监控列表中移除delete(tm.tasks,taskID)returnnil}// run 运行超时检查func(tm*TimeoutManager)run(){ticker:=time.NewTicker(100*time.Millisecond)deferticker.Stop()for{select{case<-ticker.C:tm.checkTimeouts()case<-tm.stopCh:return}}}// checkTimeouts 检查超时任务func(tm*TimeoutManager)checkTimeouts(){tm.mu.Lock()defertm.mu.Unlock()now:=time.Now()vartimeoutTasks[]*TaskTimeoutInfo// 查找超时任务for_,taskInfo:=rangetm.tasks{iftaskInfo.Status==TimeoutStatusRunning&&now.After(taskInfo.Deadline){timeoutTasks=append(timeoutTasks,taskInfo)}}// 处理超时任务for_,taskInfo:=rangetimeoutTasks{tm.handleTimeout(taskInfo)}}// handleTimeout 处理超时任务func(tm*TimeoutManager)handleTimeout(taskInfo*TaskTimeoutInfo){taskInfo.Status=TimeoutStatusTimeout// 取消上下文iftaskInfo.CancelFunc!=nil{taskInfo.CancelFunc()}// 调用回调函数iftaskInfo.Callback!=nil{gofunc(){iferr:=taskInfo.Callback(taskInfo.TaskID);err!=nil{fmt.Printf("Timeout callback failed for task %s: %v\n",taskInfo.TaskID,err)}}()}</
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/8 13:56:56

微信小程序 基于物联网技术的宠物定位与监控系统设计

目录微信小程序与物联网技术的宠物定位监控系统设计摘要项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作微信小程序与物联网技术的宠物定位监控系统设计摘要 该系统结合微信小程序与物联网技术&#xff0c…

作者头像 李华
网站建设 2026/4/14 22:32:22

Java毕设选题推荐:基于springboot的软件协作跟踪平台的设计与开发基于springboot的软件开发项目任务跟踪系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/15 1:12:30

本地 LLM 实战基础教程(非常详细),手把手教你做文本情感分析!

我们已经把一整套“大模型落地环境”铺好了&#xff1a; 用 Ollama 把开源大模型跑在本地学会 API 调用 LLM 封装把 AI 塞进 VS Code Remote SSH尝试了更偏工程和性能的 vLLM 推理框架 但这一步都会有一个真实的疑问&#xff1a; “环境是搭好了&#xff0c;但它到底能帮我…

作者头像 李华
网站建设 2026/4/15 16:31:36

基于springboot3+vue3的erp仓储管理系统的设计与实现

目录基于SpringBoot3Vue3的ERP仓储管理系统的设计与实现摘要项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作基于SpringBoot3Vue3的ERP仓储管理系统的设计与实现摘要 该系统采用前后端分离架构&#xff0c…

作者头像 李华
网站建设 2026/4/12 18:59:33

大模型项目从零到一落地(超全),收藏这一篇就够了!

年底了&#xff0c;再带着大家折腾一个新的AI大模型项目&#xff1a;基于Java快速开发并搭建MCP服务&#xff0c;并加入LLM。 在人工智能技术飞速发展的今天&#xff0c;大语言模型正在重塑我们与软件系统的交互方式。然而&#xff0c;这些强大的模型往往被困在"信息孤岛…

作者头像 李华