定时任务job (现成直接用)

news2024/11/18 12:52:15

1. 任务调度的2种方式

1. bean调用示例: 对应的类上加@Component或@Service注解, 类名.方法名(ryTask.ryNoParams) 类名首字母小写; 该类必须要在com.ruoyi 包下, 因为有校验
2. 权限类名调用示例: com.ruoyi.quartz.task.RyTask.ryNoParams

注意: class(类名)调用的时候, 只能调用com.ruoyi包中的类, 如果想要其它包也能调用, 则需修改配置
    /**
     * 定时任务白名单配置(仅允许访问的包名,如其他需要可以自行添加)
     */
    public static final String[] JOB_WHITELIST_STR = { "com.ruoyi" };

2. 默认定时任务

 预留的三个定时任务

import org.springframework.stereotype.Component;
import com.ruoyi.common.utils.StringUtils;

/**
 * 定时任务调度测试
 * 
 * @author ruoyi
 */
@Component("ryTask")
public class RyTask
{
    public void ryMultipleParams(String s, Boolean b, Long l, Double d, Integer i)
    {
        System.out.println(StringUtils.format("执行多参方法: 字符串类型{},布尔类型{},长整型{},浮点型{},整形{}", s, b, l, d, i));
    }

    public void ryParams(String params)
    {
        System.out.println("执行有参方法:" + params);
    }

    public void ryNoParams()
    {
        System.out.println("执行无参方法");
    }
}

开启ryNoParams()

执行效果:
执行无参方法
22:02:10.001 [quartzScheduler_Worker-7] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:02:10.001 [quartzScheduler_Worker-7] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 系统默认(无参)(String), DEFAULT(String), ryTask.ryNoParams(String), 系统默认(无参) 总共耗时:0毫秒(String), 0(String)
22:02:10.007 [quartzScheduler_Worker-7] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1
执行无参方法
22:02:20.000 [quartzScheduler_Worker-8] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:02:20.000 [quartzScheduler_Worker-8] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 系统默认(无参)(String), DEFAULT(String), ryTask.ryNoParams(String), 系统默认(无参) 总共耗时:0毫秒(String), 0(String)
22:02:20.012 [quartzScheduler_Worker-8] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1

 

 

开启 ryParams(String params)

 

执行效果: 
执行有参方法:ry
22:05:15.014 [quartzScheduler_Worker-10] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:05:15.014 [quartzScheduler_Worker-10] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 系统默认(有参)(String), DEFAULT(String), ryTask.ryParams('ry')(String), 系统默认(有参) 总共耗时:0毫秒(String), 0(String)
22:05:15.021 [quartzScheduler_Worker-10] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1
执行有参方法:ry
22:05:30.008 [quartzScheduler_Worker-1] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:05:30.008 [quartzScheduler_Worker-1] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 系统默认(有参)(String), DEFAULT(String), ryTask.ryParams('ry')(String), 系统默认(有参) 总共耗时:0毫秒(String), 0(String)
22:05:30.021 [quartzScheduler_Worker-1] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1

开启 ryMultipleParams(String s, Boolean b, Long l, Double d, Integer i)

 

 

执行效果: 
执行多参方法: 字符串类型ry,布尔类型true,长整型2000,浮点型316.5,整形100
22:08:00.001 [quartzScheduler_Worker-9] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:08:00.001 [quartzScheduler_Worker-9] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 系统默认(多参)(String), DEFAULT(String), ryTask.ryMultipleParams('ry', true, 2000L, 316.50D, 100)(String), 系统默认(多参) 总共耗时:0毫秒(String), 0(String)
22:08:00.001 [quartzScheduler_Worker-9] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1
执行多参方法: 字符串类型ry,布尔类型true,长整型2000,浮点型316.5,整形100
22:08:20.014 [quartzScheduler_Worker-10] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:08:20.014 [quartzScheduler_Worker-10] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 系统默认(多参)(String), DEFAULT(String), ryTask.ryMultipleParams('ry', true, 2000L, 316.50D, 100)(String), 系统默认(多参) 总共耗时:0毫秒(String), 0(String)
22:08:20.018 [quartzScheduler_Worker-10] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1

3. 新增定时任务

自定义类 MyTaskTest
package com.ruoyi.ruoyiwx.myTask;

import org.springframework.stereotype.Component;

/**
 * 注意: 该类需要在com.ruoyi 包下才会生效, 因为有校验
 */
@Component
public class MyTaskTest {

    public void myTask(){
        System.out.println("执行无参方法: ---------------myTask");
    }
}

界面上新增定时任务

执行效果: 
执行无参方法: ---------------myTask
22:57:40.004 [quartzScheduler_Worker-6] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:57:40.004 [quartzScheduler_Worker-6] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 我的定时任务(String), DEFAULT(String), myTaskTest.myTask(String), 我的定时任务 总共耗时:0毫秒(String), 0(String)
22:57:40.019 [quartzScheduler_Worker-6] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1
执行无参方法: ---------------myTask
22:57:50.003 [quartzScheduler_Worker-7] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==>  Preparing: insert into sys_job_log( job_name, job_group, invoke_target, job_message, status, create_time )values( ?, ?, ?, ?, ?, sysdate() )
22:57:50.003 [quartzScheduler_Worker-7] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - ==> Parameters: 我的定时任务(String), DEFAULT(String), myTaskTest.myTask(String), 我的定时任务 总共耗时:0毫秒(String), 0(String)
22:57:50.013 [quartzScheduler_Worker-7] DEBUG c.r.q.m.S.insertJobLog - [debug,137] - <==    Updates: 1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/971786.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++多态案例3---电脑组装

案例描述: 电脑主要组成部件为 CPU (用于计算) &#xff0c;显卡 (用于显示) &#xff0c;内存条 (用于存储)将每个零件封装出抽象基类&#xff0c;并且提供不同的厂商生产不同的零件&#xff0c;例如Intel厂商和Lenovo厂商创建电脑类提供让电脑工作的函数&#xff0c;并且调用…

uni-app 之 vue语法

uni-app 之 vue语法 image.png --- v-html 字符 --- image.png <template><view><view>{{title}}</view>--- v-html 字符 ---<view>{{title2}}</view><view v-html"title2"></view><view>{{arr}}</view&g…

【FusionInsight 迁移】HBase从C50迁移到6.5.1(02)C50上准备FTP Server

【FusionInsight 迁移】HBase从C50迁移到6.5.1&#xff08;02&#xff09;C50上准备FTP Server HBase从C50迁移到6.5.1&#xff08;02&#xff09;C50上准备FTP Server登录老集群FusionInsight C50的Manager准备FTP User准备FTP Server HBase从C50迁移到6.5.1&#xff08;02&am…

js+html实现打字游戏v2

实现逻辑&#xff0c;看jshtml实现打字游戏v1&#xff0c;在此基础之上增加了从文件读取到的单词&#xff0c;随机选取10个单词。 效果演示 上代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8">&l…

系统架构设计师(第二版)学习笔记----系统架构概述

【原文链接】系统架构设计师&#xff08;第二版&#xff09;学习笔记----系统架构概述 文章目录 一、系统架构的定义与发展历程1.1 架构的定义1.2 架构设计的作用1.3 架构设计产生的背景1.4 软件架构的发展历程1.5 模块化开发方法1.6 模块法方法分解模块遵循的原则1.7 软件工程…

SQLite简单介绍

一.简单介绍 SQLite是一款轻型的数据库&#xff0c;是遵守ACID的关系型数据库管理系统&#xff0c;它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的&#xff0c;而且已经在很多嵌入式产品中使用了它&#xff0c;它占用资源非常的低&…

CC-TAIX01 HONEYWELL 霍尼韦尔连接工厂热智商远程监测系统

CC-TAIX01 HONEYWELL 霍尼韦尔连接工厂热智商远程监测系统 -霍尼韦尔宣布霍尼韦尔连接工厂热智商,一种基于云的远程监测系统,旨在监测和管理关键的热过程数据。这是霍尼韦尔资产绩效管理(APM)投资组合的一部分。 热智商是工业和商业热应用的远程监测解决方案。它将燃烧设备连…

51单片机热水器温度控制系统仿真设计( proteus仿真+程序+原理图+报告+讲解视频)

51单片机热水器温度控制系统仿真设计 1.主要功能&#xff1a;2.仿真3. 程序代码4. 原理图5. 设计报告6. 设计资料内容清单 &&下载链接 51单片机热水器温度控制系统仿真设计( proteus仿真程序原理图报告讲解视频&#xff09; 仿真图proteus7.8及以上 程序编译器&#x…

OSCS 安全周报第 58 期:VMware Aria Operations SSH 身份验证绕过漏洞 (CVE-2023-34039)

​ 本周安全态势综述 OSCS 社区共收录安全漏洞 3 个&#xff0c;公开漏洞值得关注的是 VMware Aria Operations SSH 身份验证绕过漏洞( CVE-2023-34039 )、Apache Airflow Spark Provider 反序列化漏洞( CVE-2023-40195 )。 针对 NPM 仓库&#xff0c;共监测到 324 个不同版本…

Activiti7进阶

Activiti进阶 一、流程实例 什么是流程实例 流程实例&#xff08;ProcessInstance&#xff09;代表流程定义的执行实例。 一个流程实例包括了所有的运行节点。我们可以利用这个对象来了解当前流程实例的进度等信息。 例如&#xff1a;用户或程序按照流程定义内容发起一个流程&a…

鸿鹄工程项目管理系统em Spring Cloud+Spring Boot+前后端分离构建工程项目管理系统

Java版工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离 功能清单如下&#xff1a; 首页 工作台&#xff1a;待办工作、消息通知、预警信息&#xff0c;点击可进入相应的列表 项目进度图表&#xff1a;选择&#xff08;总体或单个&#xff09;项目显…

JavaWeb知识梳理(后端部分)

JavaWeb 静态web资源&#xff08;如html 页面&#xff09;&#xff1a;指web页面中供人们浏览的数据始终是不变。 动态web资源&#xff1a;指web页面中供人们浏览的数据是由程序产生的&#xff0c;不同时间点访问web页面看到的内容各不相同。 静态web资源开发技术&#xff1…

NAT地址转换,路由器作为出口设备,实现负载分担

路漫漫其修远兮&#xff0c;吾将上下而求索 一个善于创造的人&#xff0c;一定是一个善于分享的人。 今天整理了一个实验&#xff0c;具备NAT地址转换&#xff0c;路由器作为出口设备&#xff0c;实现负载分担&#xff0c;实现路由策略 目录 实验图 实验要求 实验配置 基…

Python Tkinter Multiple Windows 教程

一、说明 在这个Python Tkinter教程中&#xff0c;我们将学习如何在Python Tkinter中创建多个窗口&#xff0c;我们还将介绍与多个窗口相关的不同示例。而且&#xff0c;我们将介绍这些主题。 Python Tkinter multiple windows使用多个窗口的 Python Tkinter 用户注册Python Tk…

Java“牵手”唯品会商品详情数据,唯品会商品详情API接口,唯品会API接口申请指南

唯品会平台商品详情接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取唯品会商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片等详细信息 。 获取商品详情接口API是一种用于获取电商平台上商品详情数据的接口&#xff0c;…

华为Mate 60系列安装谷歌服务框架,安装Play商店,Google

华为Mate 60 Pro悄悄的上架。但是却震撼市场的强势登场,Mate 60系列默认搭载的就是鸿蒙4.0。那么mate 60加上4.0是否可以安装谷歌服务框架呢&#xff1f;本机到手经过测试是可以安装的&#xff0c;但是在解决play非保护机制认证还通知这个问题上,他和鸿蒙3.0是不一样的。如果我…

Notepad++下载安装

自己在 找Notepad发现网上的网址参差不齐&#xff0c;自己找到的一个不错下载链接见文末&#xff01; Notepad 是一个免费的代码编辑器&#xff0c;专为在微软 Windows 环境下使用。它是一个开源项目&#xff0c;采用 GPL 许可证&#xff0c;并使用 C 编程语言结合 Win32 API 和…

AI绘画:StableDiffusion实操教程-完美世界-魔女(附高清图下载)

前段时间我分享了StableDiffusion的非常完整的教程&#xff1a;“AI绘画&#xff1a;Stable Diffusion 终极宝典&#xff1a;从入门到精通 ” 尽管如此&#xff0c;还有读者反馈说&#xff0c;尽管已经成功安装&#xff0c;但生成的图片与我展示的结果相去甚远。真实感和质感之…

SW - 3D打印时遇到的审核问题(模型中存在多个壳体)

文章目录 SW - 3D打印时遇到的审核问题(模型中存在多个壳体)概述在.step中查看实体数量在.SLDPRT中查看实体数量备注END SW - 3D打印时遇到的审核问题(模型中存在多个壳体) 概述 给一个小PCB做了一个小壳子(为了使用安全和修护方便), 初步检查了一下, 没看出啥问题. 就丢给厂…

Ansys Zemax | 如何模拟自适应光学系统

概述 这篇文章介绍了如何在OpticStudio中使用多重结构创建反射式自适应光学系统。本文详细介绍了&#xff1a; 如何通过缩放光阑镜面的偏心来模拟一组镜面阵列 如何使用公差功能生成随机的波前差来模拟大气不均匀性对成像的影响 如何补偿该影响引入的像差以得到最优的几何和…