关于调度任务的问题

本贴最后更新于 2374 天前,其中的信息可能已经时移世异

以前只做过简单的定时任务
现在有这么一个需求,特来请教一下

  1. 调度任务数据库存储,web 页面维护
  2. 需要立即执行
  3. 配置重试机制,比如运行失败,如果有配置了重试的,在多久以后重试一次
  4. 暂停
  5. 启动

相关帖子

被采纳的回答

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 88250

    问题是?

    1 回复
  • someone9891

    主要是重试这块,直接 quartz 有还是要自己去怎么实现?任务执行失败,根据配置的次数和间隔去重试,直到成功或者次数用完则等待下一次执行周期

    1 回复
  • 88250

    估计得自己实现了,设计表时多弄几个状态字段和计数字段,然后定时扫表,注意幂等和并发控制,大致就这思路吧。

  • 估计要自己开发一套定时任务调度系统。

  • Ahian 1

    xxl-job

  • 14032 1 2 赞同

    我对 JeeSite 改造版加入了 Quartz 功能,应该符合你的需求, 地址 https://github.com/LYHFUU/jeesite
    04.jpg
    Job.png

    2 回复
  • someone9891

    我学习一下 👍

  • 233333

    👍 copycopy

  • someone9891

    @participants 各位大佬,又来打扰大家了, 我现在定时任务基本的需求能解决,但是又发现一个新的问题。

    quartz 数据库存储模式,已经注册到 quartz 队列中的任务,会在数据库存储,服务器重启以后还是会按照之前的周期运行,
    但是存在一个问题,我在自定义的任务表定义自己的任务。在启动的时候 遍历自己的数据注册到 quartz 中,假如直接在数据库删除了自定义的任务,服务器不管重不重启,那个任务已经注册到 quartz 中了,这种问题怎么解决,目前就是直接在数据库删除了的话,任务还会运行

    如果通过接口删除的时候,可以手动 remove,但是数据库删除就不行了

    1 回复
  • someone9891

    目前我能想到的就是
    1.在启动初始化的时候把 队列清空,但是这就与 quartz 的数据库模式初衷相违背了
    2.任务执行的时候再去数据库自定义的表查询一次,查不到就停止 并 remove 。

  • someone9891 1 评论

    这个竟然不是一个 Q&A

    我帮你改为问答帖了,悬赏积分你自己设置一下 doge
    88250
  • hjljy

    刚好我最近也在搞数据库化的 Quartz 你这个问题可以通过配置解决
    图片.png

    1 回复
  • someone9891

    更新的话,停机的时候错过的任务还会执行吗?比如预定在 2 点执行一次,但是 1 点五十停机了,2 点 10 分重启以后,2 点那一次还会执行吗

    1 回复
  • hjljy

    不會,要等下個兩點才執行

    1 回复
  • someone9891

    那就跟我说的启动的时候清空重新初始化是一样的啊,我是手动初始化,你那个配置对我是没有用的。

    而且正好也违背了 quartz 的 错过还能运行的机制。

    2 回复
  • 14032

    可了解下 CronScheduleBuilder 的三种策略

    withMisfireHandlingInstructionIgnoreMisfires() 
    withMisfireHandlingInstructionDoNothing() 
    withMisfireHandlingInstructionFireAndProceed() 
    
    1 回复
  • someone9891

    好的

  • someone9891

    配置是没错,但是假如我的任务基本信息存在数据库中,quartz 启动的时候,将我配置的任务 添加到 quartz 队列,我再从数据库删除我自己的任务信息,这条在 quartz 中的任务到时间了还是会继续运行的啊

    1 回复
  • 14032 1 1 赞同

    因为已经持久化存储了,手动删库的时候,要同时处理下 quartz 的表 QRTZ_CRON_TRIGGERS、QRTZ_TRIGGERS、QRTZ_JOB_DETAILS,这样 QuartzSchedulerThread 线程获取不到 acquireNextTriggers 触发器,就不会执行

    1 回复
  • someone9891

    对啊,如果在界面维护删除的话没问题,可以处理这些,如果直接 数据库删的话就坑爹了,算了,不想这些了 😭 想太多给自己找麻烦

  • someone9891

    image.png

    目前采用这种方式了,不知道合理不合理,在任务每次执行的时候都去数据库查询以下这条任务在自定义的表里还在不,不在电话就调用删除方法,删除方法中会 删除掉 quartz 队列里面的任务。

  • someone9891

    @participants 我发现我用 springboot 写好的 demo 都没问题了,但是集成到我们到项目里面就不行了,初始化任务可以,但是 到点不执行…… ,我们项目是使用 dubbo 的分布式项目,我只能将定时任务写在 service 层,我猜是因为 service 注册服务到 zookeeper,quartz 其实没有一个 持续的状态在运行 。。。大佬们有什么 方法吗?

    1 回复
  • someone9891

    启动日志截图:
    image.png
    quartz trigger 数据:
    image.png
    jobdetail
    image.png

    image.png

  • hjljy

    不晓得你这个是什么情况,我前两天的项目也是在 dubbo 当中用的 quartz , 具体业务是:创建一个定时任务,进行数据采集,采集完毕后,调用数据校验服务进行校验。用的是 dubbo2.6 注册中心 zk

    1 回复
  • someone9891

    没事了,是我自己把状态搞错了,任务我设置的是暂停。。。1 是暂停 2 是正常,我 一直以为 1 是正常,在数据库插入的是 1

请输入回帖内容 ...

推荐标签 标签

  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 2 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 367 关注
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    6 引用 • 144 回帖
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    269 引用 • 666 回帖 • 1 关注
  • AWS
    11 引用 • 28 回帖 • 2 关注
  • 安装

    你若安好,便是晴天。

    134 引用 • 1184 回帖 • 2 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    695 引用 • 538 回帖 • 1 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 236 关注
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 342 关注
  • 创业

    你比 99% 的人都优秀么?

    81 引用 • 1396 回帖 • 1 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 63 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 475 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    34 引用 • 333 回帖
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 121 关注
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    117 引用 • 99 回帖 • 191 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 46 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    182 引用 • 400 回帖
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    43 引用 • 130 回帖 • 259 关注
  • abitmean

    有点意思就行了

    44 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖
  • 电影

    这是一个不能说的秘密。

    125 引用 • 610 回帖
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    34 引用 • 37 回帖 • 565 关注
  • 音乐

    你听到信仰的声音了么?

    63 引用 • 513 回帖
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    293 引用 • 4496 回帖 • 687 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖