@Test public void createWithoutJobDetail() throws ParseException { CronTriggerFactoryBean factory = new CronTriggerFactoryBean(); factory.setName("myTrigger"); factory.setCronExpression("0 15 10 ? * *"); factory.afterPropertiesSet(); CronTrigger trigger = factory.getObject(); assertEquals("0 15 10 ? * *", trigger.getCronExpression()); }
public void init() { try { MethodInvokingJobDetailFactoryBean jobDetail = new MethodInvokingJobDetailFactoryBean(); jobDetail.setTargetObject(transactionRecovery); jobDetail.setTargetMethod("startRecover"); jobDetail.setName("transactionRecoveryJob"); jobDetail.setConcurrent(false); jobDetail.afterPropertiesSet(); CronTriggerFactoryBean cronTrigger = new CronTriggerFactoryBean(); cronTrigger.setBeanName("transactionRecoveryCronTrigger"); cronTrigger.setCronExpression(transactionConfigurator.getRecoverConfig().getCronExpression()); cronTrigger.setJobDetail(jobDetail.getObject()); cronTrigger.afterPropertiesSet(); scheduler.scheduleJob(jobDetail.getObject(), cronTrigger.getObject()); scheduler.start(); } catch (Exception e) { throw new SystemException(e); } }
/** * * @return * @throws ParseException */ public CronTrigger build() throws ParseException { triggerFactoryBean.afterPropertiesSet(); return triggerFactoryBean.getObject(); } }
@Override public void afterPropertiesSet() throws ParseException{ super.afterPropertiesSet(); //Remove the JobDetail element getJobDataMap().remove(JOB_DETAIL_KEY); } }
private CronTriggerFactoryBean createCronTrigger(String name, JobDetail jobDetail, String corn) throws ParseException { CronTriggerFactoryBean factoryBean = new CronTriggerFactoryBean(); factoryBean.setName(name); factoryBean.setJobDetail(jobDetail); factoryBean.setCronExpression(corn); factoryBean.afterPropertiesSet(); return factoryBean; }
@Override public Trigger buildTrigger(JobTrigger jobTrigger, JobDetail jobDetail) { Preconditions.checkArgument(isApplicable(jobTrigger.getClass()), "Not supported jobTrigger type: " + jobTrigger.getClass()); cronTriggerFactoryBean.setCronExpression(((CronJobTrigger) jobTrigger).getCronExpression()); cronTriggerFactoryBean.setJobDetail(jobDetail); cronTriggerFactoryBean.setGroup(jobDetail.getKey().getGroup()); cronTriggerFactoryBean.setName(jobDetail.getKey().getName()); Map<String, Object> triggerInstance = new HashMap<String, Object>(); triggerInstance.put(JOB_TRIGGER_CLASS, CronJobTrigger.class.getName()); triggerInstance.put(JOB_TRIGGER_INSTANCE, convertToList((CronJobTrigger) jobTrigger)); jobDetail.getJobDataMap().putAll(triggerInstance); // This not work // cronTriggerFactoryBean.setJobDataAsMap(triggerInstance); try { cronTriggerFactoryBean.afterPropertiesSet(); } catch (ParseException e) { throw new GeneralServiceException(e); } return cronTriggerFactoryBean.getObject(); }
/** * 通过工厂类创建Trigger * @param jobDetailFactoryBean * @return * @throws ParseException */ @Bean(name = "cronTriggerBean") public Trigger cronTriggerBean(MethodInvokingJobDetailFactoryBean jobDetailFactoryBean) throws ParseException { CronTriggerFactoryBean cronTriggerFactoryBean = new CronTriggerFactoryBean(); cronTriggerFactoryBean.setJobDetail(jobDetailFactoryBean.getObject()); cronTriggerFactoryBean.setCronExpression("0/3 * * * * ?");//每3秒执行一次 cronTriggerFactoryBean.setName("customCronTrigger"); cronTriggerFactoryBean.afterPropertiesSet(); return cronTriggerFactoryBean.getObject(); }
/** * 根据参数,创建对应的CronTrigger对象 * * @param job * @param time * @param name * @param groupName * @param description * @return */ public static CronTrigger createCronTrigger(JobDetail job, String time, String name, String groupName, String description) { factoryBean.setName(name); factoryBean.setJobDetail(job); factoryBean.setCronExpression(time); factoryBean.setDescription(description); factoryBean.setGroup(groupName); try { factoryBean.afterPropertiesSet(); } catch (ParseException e) { e.printStackTrace(); } return factoryBean.getObject(); } }
// Create Job JobDetailFactoryBean JobDetail = new JobDetailFactoryBean(); jobDetail.setJobClass(ScheduledJob.class); jobDetail.setName("reportJob1"); jobDetail.setDurability(true); jobDetail.setJobDataMap(new JobDataMap()); jobDetail.afterPropertiesSet(); // create CRON Trigger CronTriggerFactoryBean trigger = new CronTriggerFactoryBean(); trigger.setBeanName("UniqueCronBeanName"); trigger.setGroup("uniqueCronGroup"); trigger.setJobDetail(jobDetail.getObject()); trigger.setCronExpression("0 0 12 * * ?"); trigger.afterPropertiesSet();
// Create Job JobDetailFactoryBean JobDetail = new JobDetailFactoryBean(); jobDetail.setJobClass(ScheduledJob.class); jobDetail.setName("reportJob1"); jobDetail.setDurability(true); jobDetail.setJobDataMap(new JobDataMap()); jobDetail.afterPropertiesSet(); // create CRON Trigger CronTriggerFactoryBean trigger = new CronTriggerFactoryBean(); trigger.setBeanName("UniqueCronBeanName"); trigger.setGroup("uniqueCronGroup"); trigger.setJobDetail(jobDetail.getObject()); trigger.setCronExpression("0 0 12 * * ?"); trigger.afterPropertiesSet();
public CronTriggerFactoryBean cronTriggerFactoryBean(JobDetailFactoryBean jobDetailFactory, Long id, String cronExpression, Date startDateTime, Date enddatetime) throws ParseException { CronTriggerFactoryBean cronTriggerFactory = new CronTriggerFactoryBean(); cronTriggerFactory.setJobDetail(jobDetailFactory.getObject()); cronTriggerFactory.setStartDelay(3000); cronTriggerFactory.setName(triggerName + "_" + id); cronTriggerFactory.setGroup(groupName); logger.debug(EELFLoggerDelegate.debugLogger, triggerName + " Scheduled: " + cronExpression); cronTriggerFactory.setCronExpression( cronExpression); //"0 * * * * ? *" cronTriggerFactory.afterPropertiesSet(); final CronTriggerImpl cronTrigger = (CronTriggerImpl) cronTriggerFactory.getObject(); cronTrigger.setStartTime(startDateTime == null ? Calendar.getInstance().getTime() : startDateTime); cronTrigger.setEndTime(enddatetime); Date fireAgainTime = cronTrigger.getFireTimeAfter(cronTrigger.getStartTime()); if (fireAgainTime == null) throw new IllegalArgumentException("Cron not added as it may not fire again " + " Expr: " + cronExpression + " End Time: " + cronTrigger.getEndTime()); return cronTriggerFactory; }
factoryBean.setMisfireInstruction(cronTrigger.misfireInstruction().getMisfireInstruction()); factoryBean.afterPropertiesSet();
private void scheduleReport(ReportDefinition reportDef) throws ClassNotFoundException, NoSuchMethodException, ParseException, SchedulerException, Exception { //this is most likely reentrant since the method is private and called from start via plural version. synchronized (m_scheduler) { MethodInvokingJobDetailFactoryBean jobFactory = new MethodInvokingJobDetailFactoryBean(); jobFactory.setTargetObject(this); jobFactory.setTargetMethod("runReport"); jobFactory.setArguments(new Object[] { reportDef }); jobFactory.setConcurrent(false); jobFactory.setBeanName(reportDef.getDescription()); jobFactory.afterPropertiesSet(); JobDetail jobDetail = (JobDetail) jobFactory.getObject(); CronTriggerFactoryBean cronReportTrigger = new CronTriggerFactoryBean(); cronReportTrigger.setBeanName(reportDef.getDescription()); cronReportTrigger.setJobDetail(jobDetail); cronReportTrigger.setCronExpression(reportDef.getCronExpression()); cronReportTrigger.afterPropertiesSet(); m_scheduler.scheduleJob(jobDetail, cronReportTrigger.getObject()); LOG.debug("Schedule report {}", cronReportTrigger); } }