quartz定时器 Job的execute使用动态参数

本文介绍了一个通过定时任务来更新特定站点的搜索引擎索引的方法。该方法使用了JobDTO对象来设置作业详情,并利用Quartz调度器来实现每天凌晨0点执行更新操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@GetMapping({"/addSearchIndexBySite"})
    public JsonResult addSearchIndexBySite(@RequestParam(required = false) String site) throws SchedulerException, ClassNotFoundException, IllegalAccessException, InstantiationException {
        JobDTO dto = new JobDTO();
        dto.setBeanName("tech.liveeasy.platform.kapok.elt.scheduler.UpdateSearchIndexJob");
        dto.setJobName("updateSearchIndexJob" + site);
        dto.setTriggerName("updateSearchIndexTrigger" + site);
        dto.setCronExpression("0 0 0 * * ? ");//每天0点

        JobDetail jobDetail = JobBuilder.newJob(UpdateSearchIndexJob.class)
                .withIdentity(dto.getJobName())
                .usingJobData("site", site)//在此处添加需要用的参数即可
                .build();
        CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(dto.getCronExpression());
        Trigger cronTrigger = newTrigger()
                .withIdentity(dto.getTriggerName())
                .startNow()
                .withSchedule(scheduleBuilder)
                .build();
        try {
            scheduler.scheduleJob(jobDetail, cronTrigger);
        } catch (ObjectAlreadyExistsException e) {
            String result = "Unable to store Job, because one already exists with this identification.";
            return new JsonResult(ResultCode.SYS_ERROR, "异常", result);
        }
        return new JsonResult(ResultCode.SUCCESS, "成功", dto);
    }
@Component
public class UpdateSearchIndexJob implements Job {

    @Override
    public void execute(JobExecutionContext context) {
        String site = null;
        try {//获取参数使用
            context.getMergedJobDataMap().getString("site");
        } catch (Exception e){
            site = null;
        }
 }
也可以这么用

trigger = trigger.getTriggerBuilder()
                .withIdentity(triggerKey)
                .usingJobData("site", jobDTO.getSite())
                .withSchedule(scheduleBuilder)
                .build();



site = context.getTrigger().getJobDataMap().getString("site");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值