关于调度任务的问题

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

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

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

相关帖子

被采纳的回答

欢迎来到这里!

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

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

    问题是?

    1 回复
  • someone9891 via iPhone

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

    1 回复
  • 88250

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

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

  • Ahian 1

    xxl-job

  • 14032 1 2 赞同

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

    2 回复
  • someone9891 via macOS

    我学习一下 👍

  • 233333

    👍 copycopy

  • someone9891 via macOS

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

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

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

    1 回复
  • someone9891 via macOS

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

  • someone9891 1 评论 via macOS

    这个竟然不是一个 Q&A

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

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

    1 回复
  • someone9891 via macOS

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

    1 回复
  • hjljy

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

    1 回复
  • someone9891 via macOS

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

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

    2 回复
  • 14032

    可了解下 CronScheduleBuilder 的三种策略

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

    好的

  • someone9891 via macOS

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

    1 回复
  • 14032 1 1 赞同

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

    1 回复
  • someone9891 via macOS

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

  • someone9891 via macOS

    image.png

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

  • someone9891 via macOS

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

    1 回复
  • someone9891 via macOS

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

    image.png

  • hjljy

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

    1 回复
  • someone9891 via macOS

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

请输入回帖内容 ...

推荐标签 标签

  • Firefox

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

    7 引用 • 30 回帖 • 384 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 182 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    59 引用 • 25 回帖 • 1 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    76 引用 • 1742 回帖 • 3 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 490 关注
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3201 引用 • 8216 回帖
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 183 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖 • 1 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 2 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    326 引用 • 1395 回帖
  • sts
    2 引用 • 2 回帖 • 241 关注
  • 叶归
    11 引用 • 47 回帖 • 20 关注
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1281 回帖 • 3 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    29 引用 • 202 回帖 • 27 关注
  • Anytype
    3 引用 • 31 回帖 • 24 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 612 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 187 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 650 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 3 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 80 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    108 引用 • 295 回帖 • 2 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 450 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1794 回帖 • 1 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    89 引用 • 1251 回帖 • 394 关注