打造全方位接口自动化测试平台:任务调度功能实现

目前正在着手开发一款功能全面的接口自动化测试平台,该平台将涵盖登录、用户管理、权限控制、项目管理、用例管理、测试数据管理、测试报告生成、任务调度、缺陷跟踪以及系统配置等多个核心模块。在测试过程中,我们会用到定时任务,比如:定时更新bug状态等。所以我们本篇内容介绍一个定时任务的功能实现。
在这里插入图片描述

技术选型

  • 后端:采用Java作为主要开发语言。
  • 前端:使用VUE框架进行界面展示。
  • 定时任务: 使用ScheduledTaskRegistrarTrigger接口。

定时任务功能设计

为了定时任务做持久化,首先我们需要把想要执行的定时任务保存到数据库中或缓存中,保证我们服务异常或者更新、重启后,不影响已经存在的定时任务。其次我们将实现3种类型的定时任务(固定延迟、固定频率、Cron表达式)。

调度策略枚举

public enum SchedulingStrategy {
    FIXED_DELAY,
    FIXED_RATE,
    CRON
}

任务调度工具类

@Configuration
public class TaskSchedulers {

    private final Map<String, ScheduledFuture<?>> scheduledTasks = new HashMap<>();
    private final TaskScheduler taskScheduler;

    @Autowired
    public TaskSchedulers(TaskScheduler taskScheduler) {
        this.taskScheduler = taskScheduler;
    }

    @Bean
    public TaskScheduler taskScheduler() {
        ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
        scheduler.setPoolSize(10);
        scheduler.initialize();
        return scheduler;
    }

    public String scheduleTask(String taskId, Runnable task, SchedulingStrategy strategy, Object... strategyArgs) {
        ScheduledFuture<?> future;
        switch (strategy) {
            case FIXED_DELAY:
                long delay = (Long) strategyArgs[0];
                future = taskScheduler.scheduleWithFixedDelay(task, delay);
                break;
            case FIXED_RATE:
                long rate = (Long) strategyArgs[0];
                future = taskScheduler.scheduleAtFixedRate(task, rate);
                break;
            case CRON:
                String cronExpression = (String) strategyArgs[0];
                Trigger cronTrigger = new CronTrigger(cronExpression);
                future = taskScheduler.schedule(task, cronTrigger);
                break;
            default:
                log.info("不支持的调度策略:{}", strategy);
        }
        scheduledTasks.put(taskId, future);
        return taskId; // Optionally return the task ID for later cancellation
    }

    public void cancelTask(String taskId) {
        ScheduledFuture<?> future = scheduledTasks.remove(taskId);
        if (future != null) {
            future.cancel(false);
        }
    }
}

使用方法介绍

scheduleWithFixedDelayscheduleAtFixedRate 方法没有直接接受延迟或速率的单位,它们默认使用毫秒。如果你需要使用不同的时间单位,你可以创建一个PeriodicTrigger并设置其周期和单位。

对于Cron表达式,使用了CronTrigger类来封装Cron表达式。这是Spring提供的一个便利类,用于解析和计算Cron表达式的下一次执行时间。

strategyArgs 是一个可变参数列表,它允许你传递策略所需的不同数量的参数。在这个例子中,固定延迟和固定频率策略需要一个long类型的参数(表示毫秒数),而Cron策略需要一个String类型的参数(表示Cron表达式)。

添加了一个@Bean注解的方法来创建TaskScheduler实例。这确保了Spring容器将管理TaskScheduler的生命周期。

scheduleTask 方法返回了任务ID(在这个例子中,它就是传入的taskId),这样就可以稍后使用它来取消任务。

在应用中的任何地方注入TaskSchedulers,调用scheduleTask方法来调度任务。

@Autowired
private TaskSchedulers taskSchedulers;

public void someMethod() {
    Runnable task = () -> System.out.println("Task executed at: " + System.currentTimeMillis());
    TaskSchedulers.scheduleTask("myTask", task, SchedulingStrategy.FIXED_RATE, 5000L); // 每5秒执行一次
    // 或者使用Cron表达式
    // TaskSchedulers.scheduleTask("myCronTask", task, SchedulingStrategy.CRON, "0/10 * * * * ?"); // 每10秒执行一次
}
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或 EJBs。 Quartz的优势: 1、Quartz是一个任务调度框架(库),它几乎可以集成到任何应用系统中。 2、Quartz是非常灵活的,它让您能够以最“自然”的方式来编写您的项目的代码,实现您所期望的行为 3、Quartz是非常轻量级的,只需要非常少的配置 —— 它实际上可以被跳出框架来使用,如果你的需求是一些相对基本的简单的需求的话。 4、Quartz具有容错机制,并且可以在重启服务的时候持久化(”记忆”)你的定时任务,你的任务也不会丢失。 5、可以通过Quartz,封装成自己的分布式任务调度实现强大的功能,成为自己的产品。6、有很多的互联网公司也都在使用Quartz。比如美团 Spring是一个很优秀的框架,它无缝的集成了Quartz,简单方便的让企业级应用更好的使用Quartz进行任务的调度。   课程说明:在我们的日常开发中,各种大型系统的开发少不了任务调度,简单的单机任务调度已经满足不了我们的系统需求,复杂的任务会让程序猿头疼, 所以急需一套专门的框架帮助我们去管理定时任务,并且可以在多台机器去执行我们的任务,还要可以管理我们的分布式定时任务。本课程从Quartz框架讲起,由浅到深,从使用到结构分析,再到源码分析,深入解析Quartz、Spring+Quartz,并且会讲解相关原理, 让大家充分的理解这个框架和框架的设计思想。由于互联网的复杂性,为了满足我们特定的需求,需要对Spring+Quartz进行二次开发,整个二次开发过程都会进行讲解。Spring被用在了越来越多的项目中, Quartz也被公认为是比较好用的定时器设置工具,学完这个课程后,不仅仅可以熟练掌握分布式定时任务,还可以深入理解大型框架的设计思想。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值