Skip to content

Instantly share code, notes, and snippets.

@mnadeem
Last active January 18, 2017 10:35
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mnadeem/367f115cff54b704c91b4813b240b1fd to your computer and use it in GitHub Desktop.
Save mnadeem/367f115cff54b704c91b4813b240b1fd to your computer and use it in GitHub Desktop.
Listener to execute the quartz job with fixed delay
import static org.quartz.TriggerBuilder.newTrigger;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.quartz.JobDataMap;
import org.quartz.JobDetail;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SimpleTrigger;
import org.quartz.Trigger;
import org.quartz.TriggerKey;
import org.quartz.listeners.JobListenerSupport;
/**
*Add the following in the JobDataMap
*<pre>
*public class SimpleJob implements Job {
*
* public void execute(JobExecutionContext context) throws JobExecutionException {
*
* JobDataMap map = context.getJobDetail().getJobDataMap();
*
* map.put(FixedDelayJobListener.FIXED_DELAY_JOB_DATA, new FixdedDelayJobData(2L));
* // Perform the job operation
* :
* :
* }
* }
* </pre>
*
* Add the listener
* <pre>
* {@code scheduler.getListenerManager().addJobListener(new FixedDelayJobListener());}
* </pre>
* Schedule the job as follows
* <pre>
* JobDetail job = newJob(SimpleJob.class).withIdentity("statefulJob", "group1").build();
*
* Trigger trigger = newTrigger()
* .withIdentity("trigger1", "group1")
* .startAt(startTime)
* .build();
*
* scheduler.scheduleJob(job, trigger);
* </pre>
*
*/
public final class FixedDelayJobListener extends JobListenerSupport {
private static final String FIXED_JOB_LISTENER_NAME = "FixedDelayJobListener";
public static final String FIXED_DELAY_JOB_DATA = "FIXED_DELAY_JOB_DATA";
@Override
public String getName() {
return FIXED_JOB_LISTENER_NAME;
}
@Override
public void jobWasExecuted(final JobExecutionContext context, final JobExecutionException exception) {
JobDetail jobdetail = context.getJobDetail();
JobDataMap data = jobdetail.getJobDataMap();
if (!data.containsKey(FIXED_DELAY_JOB_DATA)) {
getLog().debug("Not a fixed delay job : {}", context.getJobDetail().getKey());
return;
}
if (shouldNotSchedule(context)) {
getLog().debug("Not scheduling {} again as there is still an unfired trigger.", context.getJobDetail().getKey());
return;
} else {
getLog().debug("Rescheduling {} as there is no unfired trigger.", context.getJobDetail().getKey());
}
TriggerKey oldTriggerKey = context.getTrigger().getKey();
FixdedDelayJobData jobData = (FixdedDelayJobData) data.getWrappedMap().get(FIXED_DELAY_JOB_DATA);
Trigger newTrigger = buildNewTrigger(jobData, oldTriggerKey);
rescheduleJob(context.getScheduler(), oldTriggerKey, newTrigger);
}
private boolean shouldNotSchedule(final JobExecutionContext context) {
List<? extends Trigger> triggersOfJob = getTriggersOfJob(context);
for (Trigger trigger : triggersOfJob) {
if (trigger instanceof SimpleTrigger && ((SimpleTrigger) trigger).getTimesTriggered() == 0) {
return true;
}
}
return false;
}
private List<? extends Trigger> getTriggersOfJob(final JobExecutionContext context) {
List<? extends Trigger> triggersOfJob = new ArrayList<Trigger>();
try {
triggersOfJob = context.getScheduler().getTriggersOfJob(context.getJobDetail().getKey());
} catch (SchedulerException e) {
getLog().error(e.getMessage());
}
return triggersOfJob;
}
private Trigger buildNewTrigger(final FixdedDelayJobData jobData, final TriggerKey oldTriggerKey) {
Date runTime = jobData.getNextScheduleDate();
Trigger newTrigger = newTrigger().withIdentity(oldTriggerKey).startAt(runTime).build();
return newTrigger;
}
public void rescheduleJob(final Scheduler scheduler, final TriggerKey oldTriggerKey, final Trigger newTrigger) {
try {
if (!scheduler.isShutdown()) {
scheduler.rescheduleJob(oldTriggerKey, newTrigger);
}
} catch (SchedulerException se) {
getLog().error("failed to reschedule the job with triger : {}", oldTriggerKey, se);
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment