V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Sponsored by
LinkedIn
2000 个不用坐班的远程好工作在召唤你 · 弹性上班不打卡,工作和生活都能拥有
2000 个不用坐班的全球远程工作,帮助 V2EX 的小伙伴开启全新的工作方式。
Promoted by LinkedIn
frank1256
V2EX  ›  程序员

异步任务状态机有啥好的解决方案吗?

  •  
  •   frank1256 · 176 天前 · 1139 次点击
    这是一个创建于 176 天前的主题,其中的信息可能已经有所发展或是发生改变。

    rt

    背景:删除耗时的资源,状态机有:删除中,删除成功,删除失败。(创建功能一样,就是创建中,创建成功、创建失败)

    api 调用时,前端可以发起批量动作,例如批量删除耗时资源。我的流程就是数据库批量数据更新为删除中,然后起多个线程去异步调用真实的耗时接口。直接返回前端操作成功。异步完成后会更新数据库状态为删除成功

    异常处理: 由于都是在内存中,如果服务重启,即无法知道结果。目前解决方案是每次启动之前都捞出“XX 中”的状态任务,先调查询结果接口,进行数据库更新,或者重新发起。

    疑问: 目前有很多这种异步耗时又有状态的资源。我想着给他们抽象出来做成统一,有啥方案或者目前有什么开源的任务调度能解决状态机的东西吗?

    3 条回复    2022-04-02 09:14:31 +08:00
    zmal
        2
    zmal  
       176 天前
    这不是典型的发布 /订阅场景吗...如果不想用外部 MQ ,可以用 guava 的 EventBus 类似的东西,EventBus 支持异步。
    tedzhou1221
        3
    tedzhou1221  
       175 天前
    用个定时调度应该可以了吧,例如 xxl-job 之类 的。
    关于   ·   帮助文档   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1810 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 17:03 · PVG 01:03 · LAX 10:03 · JFK 13:03
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.