當前位置: 首頁>>代碼示例>>Java>>正文


Java JobDetail類代碼示例

本文整理匯總了Java中org.quartz.JobDetail的典型用法代碼示例。如果您正苦於以下問題:Java JobDetail類的具體用法?Java JobDetail怎麽用?Java JobDetail使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


JobDetail類屬於org.quartz包,在下文中一共展示了JobDetail類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: insertJobListener

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * <p>
 * Associate a listener with a job.
 * </p>
 * 
 * @param conn
 *          the DB Connection
 * @param job
 *          the job to associate with the listener
 * @param listener
 *          the listener to insert
 * @return the number of rows inserted
 */
public int insertJobListener(Connection conn, JobDetail job, String listener)
    throws SQLException {
    PreparedStatement ps = null;

    try {
        ps = conn.prepareStatement(rtp(INSERT_JOB_LISTENER));
        ps.setString(1, job.getName());
        ps.setString(2, job.getGroup());
        ps.setString(3, listener);

        return ps.executeUpdate();
    } finally {
        closeStatement(ps);
    }
}
 
開發者ID:AsuraTeam,項目名稱:asura,代碼行數:29,代碼來源:StdJDBCDelegate.java

示例2: prvateAddQuartz

import org.quartz.JobDetail; //導入依賴的package包/類
private boolean prvateAddQuartz(Class<? extends Job> jobClass,JobKey jobKey, CronScheduleBuilder builder, SimpleScheduleBuilder repeatForever) {
	if(scheduler==null){
		init();
	}
	//創建一個任務計劃生成器	設置任務名稱與分組	創建任務計劃
	JobDetail job = JobBuilder.newJob(jobClass).withIdentity(jobKey).build();
	//創建一個觸發生成器	設置觸發器名稱與分組	設置觸發器出發條件	創建觸發器
	Trigger trigger = TriggerBuilder.newTrigger().withIdentity(jobKey.getName(),jobKey.getGroup()).withSchedule(builder==null?repeatForever:builder).build();
	try {
		scheduler.scheduleJob(job, trigger);
		outLog("添加任務計劃成功!");
		return true;
	} catch (SchedulerException e) {
		outLog("添加任務計劃失敗!");
	}
	return false;
}
 
開發者ID:zhiqiang94,項目名稱:BasicsProject,代碼行數:18,代碼來源:QuartzUtil.java

示例3: insertExtendedTriggerProperties

import org.quartz.JobDetail; //導入依賴的package包/類
public int insertExtendedTriggerProperties(Connection conn, OperableTrigger trigger, String state, JobDetail jobDetail) throws SQLException, IOException {

        SimpleTrigger simpleTrigger = (SimpleTrigger)trigger;
        
        PreparedStatement ps = null;
        
        try {
            ps = conn.prepareStatement(Util.rtp(INSERT_SIMPLE_TRIGGER, tablePrefix, schedNameLiteral));
            ps.setString(1, trigger.getKey().getName());
            ps.setString(2, trigger.getKey().getGroup());
            ps.setInt(3, simpleTrigger.getRepeatCount());
            ps.setBigDecimal(4, new BigDecimal(String.valueOf(simpleTrigger.getRepeatInterval())));
            ps.setInt(5, simpleTrigger.getTimesTriggered());

            return ps.executeUpdate();
        } finally {
            Util.closeStatement(ps);
        }
    }
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:20,代碼來源:SimpleTriggerPersistenceDelegate.java

示例4: updateMethodInovkeJob

import org.quartz.JobDetail; //導入依賴的package包/類
public JobDetail updateMethodInovkeJob(String schedulerName, String jobName, String jobGroup, String jobClass,
                                    Object[] constructorArguments, String jobClassMethodName,
                                    Object[] jobClassMethodArgs, String description) throws SchedulerException {
    Assert.notNull(jobClass, "jobClass can not be null");
    Assert.notEmpty(schedulerName, "schedulerName can not be empty");
    Assert.notEmpty(jobName, "jobName can not be empty");
    Assert.notEmpty(jobGroup, "jobGroup can not be empty");
    Assert.notEmpty(jobClassMethodName, "jobClassMethodName can not be empty");
    JobDataMap jobDataMap = new JobDataMap();
    jobDataMap.put("jobClass", jobClass);
    jobDataMap.put("constructorArguments", constructorArguments);
    jobDataMap.put("jobClassMethodName", jobClassMethodName);
    jobDataMap.put("jobClassMethodArgs", jobClassMethodArgs);
    JobDetail jobDetail = JobBuilder.newJob(MethodInvokeJob.class).withIdentity(jobName, jobGroup)
            .withDescription(description).setJobData(jobDataMap).storeDurably().build();
    updateJob(schedulerName, jobDetail);
    return jobDetail;
}
 
開發者ID:quartzweb,項目名稱:quartz-web,代碼行數:19,代碼來源:QuartzManager.java

示例5: createScheduleJob

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * 創建定時任務
 */
public static void createScheduleJob(Scheduler scheduler, ScheduleJobEntity scheduleJob) {
    try {
    	//構建job信息
        JobDetail jobDetail = JobBuilder.newJob(ScheduleJob.class).withIdentity(getJobKey(scheduleJob.getJobId())).build();

        //表達式調度構建器
        CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(scheduleJob.getCronExpression())
        		.withMisfireHandlingInstructionDoNothing();

        //按新的cronExpression表達式構建一個新的trigger
        CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity(getTriggerKey(scheduleJob.getJobId())).withSchedule(scheduleBuilder).build();

        //放入參數,運行時的方法可以獲取
        jobDetail.getJobDataMap().put(ScheduleJobEntity.JOB_PARAM_KEY, new Gson().toJson(scheduleJob));

        scheduler.scheduleJob(jobDetail, trigger);

        //暫停任務
        if(scheduleJob.getStatus() == ScheduleStatus.PAUSE.getValue()){
        	pauseJob(scheduler, scheduleJob.getJobId());
        }
    } catch (SchedulerException e) {
        throw new RRException("創建定時任務失敗", e);
    }
}
 
開發者ID:gyp220203,項目名稱:renren-msg,代碼行數:29,代碼來源:ScheduleUtils.java

示例6: findJob

import org.quartz.JobDetail; //導入依賴的package包/類
@Transactional(readOnly = true)
public Optional<JobDescriptor> findJob(String group, String name) {
	// @formatter:off
	try {
		JobDetail jobDetail = scheduler.getJobDetail(jobKey(name, group));
		if(Objects.nonNull(jobDetail))
			return Optional.of(
					JobDescriptor.buildDescriptor(jobDetail, 
							scheduler.getTriggersOfJob(jobKey(name, group))));
	} catch (SchedulerException e) {
		log.error("Could not find job with key - {}.{} due to error - {}", group, name, e.getLocalizedMessage());
	}
	// @formatter:on
	log.warn("Could not find job with key - {}.{}", group, name);
	return Optional.empty();
}
 
開發者ID:juliuskrah,項目名稱:quartz-manager,代碼行數:17,代碼來源:EmailService.java

示例7: wrapScheduleJob

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * 封裝ScheduleJob對象
 * 
 * @param scheduleJob
 * @param scheduler
 * @param jobKey
 * @param trigger
 */
private void wrapScheduleJob(ScheduleJobEntity scheduleJob,
		Scheduler scheduler, JobKey jobKey, Trigger trigger) {
	try {
		scheduleJob.setJobName(jobKey.getName());
		scheduleJob.setJobGroup(jobKey.getGroup());

		JobDetail jobDetail = scheduler.getJobDetail(jobKey);
		scheduleJob.setJobClass(jobDetail.getJobClass());
		scheduleJob.setJobDesc(jobDetail.getDescription());
		
		Trigger.TriggerState triggerState = scheduler.getTriggerState(trigger.getKey());
		scheduleJob.setTriggerStatus(triggerState.name());
		
		if (trigger instanceof CronTrigger) {
			CronTrigger cronTrigger = (CronTrigger) trigger;
			TriggerKey triggerKey = cronTrigger.getKey();
			scheduleJob.setTriggerName(triggerKey.getName());
			scheduleJob.setTriggerGroup(triggerKey.getGroup());
			scheduleJob.setNextFireTime(cronTrigger.getNextFireTime());
			scheduleJob.setCronExpression(cronTrigger.getCronExpression());
			scheduleJob.setStartDate(cronTrigger.getStartTime());
			scheduleJob.setEndDate(cronTrigger.getEndTime());
		}
	} catch (SchedulerException e) {
		logger.error("獲取觸發器狀態失敗", e);
		throw new ServiceException(e);
	}
}
 
開發者ID:wjggwm,項目名稱:webside,代碼行數:37,代碼來源:ScheduleJobServiceImpl.java

示例8: testCodedCronTriggerBean

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * Ensures that jobs that are coded without a delay run without delay.
 * @throws Exception
 */
@Test
public void testCodedCronTriggerBean() throws Exception
{
    final String JOB_NAME = "codedCronJob";
    List<Long> jobRuns = this.getRunList(JOB_NAME);
    assertEquals(0, jobRuns.size());
    scheduler = StdSchedulerFactory.getDefaultScheduler();
    scheduler.start();
    CronTriggerBean ctBean = new CronTriggerBean();
    ctBean.setBeanName("Dummy");
    ctBean.setCronExpression("0/1 * * * * ? *");
    ctBean.setEnabled(true);
    JobDetail jobDetail = new JobDetail(JOB_NAME, "DefaultGroup", DummyJob.class);
    ctBean.setJobDetail(jobDetail);
    ctBean.setScheduler(scheduler);
    ctBean.afterPropertiesSet();

    assertJobRunsAfterInterval(jobRuns);
    scheduler.shutdown();
    this.assertJobStopsAfterShutdown(jobRuns);
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:26,代碼來源:CronTriggerBeanTest.java

示例9: updateExtendedTriggerProperties

import org.quartz.JobDetail; //導入依賴的package包/類
public int updateExtendedTriggerProperties(Connection conn, OperableTrigger trigger, String state, JobDetail jobDetail) throws SQLException, IOException {

        CronTrigger cronTrigger = (CronTrigger)trigger;
        
        PreparedStatement ps = null;

        try {
            ps = conn.prepareStatement(Util.rtp(UPDATE_CRON_TRIGGER, tablePrefix, schedNameLiteral));
            ps.setString(1, cronTrigger.getCronExpression());
            ps.setString(2, cronTrigger.getTimeZone().getID());
            ps.setString(3, trigger.getKey().getName());
            ps.setString(4, trigger.getKey().getGroup());
            
            return ps.executeUpdate();
        } finally {
            Util.closeStatement(ps);
        }
    }
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:19,代碼來源:CronTriggerPersistenceDelegate.java

示例10: startIndexerJob

import org.quartz.JobDetail; //導入依賴的package包/類
private void startIndexerJob() throws SchedulerException {
    Scheduler scheduler = Singleton.getScheduler();
    // Setup the indexer which runs forever indexing
    JobDetail job = newJob(IndexJob.class)
            .withIdentity("indexjob")
            .build();

    SimpleTrigger trigger = newTrigger()
            .withIdentity("indexerjob")
            .withSchedule(simpleSchedule()
                    .withIntervalInHours(24)
                    .repeatForever()
            )
            .build();

    scheduler.scheduleJob(job, trigger);
    scheduler.start();
}
 
開發者ID:boyter,項目名稱:freemoz,代碼行數:19,代碼來源:JobService.java

示例11: updateJob

import org.quartz.JobDetail; //導入依賴的package包/類
public void updateJob(String group, String name, JobDescriptor descriptor) {
	try {
		JobDetail oldJobDetail = scheduler.getJobDetail(jobKey(name, group));
		if(Objects.nonNull(oldJobDetail)) {
			JobDataMap jobDataMap = oldJobDetail.getJobDataMap();
			jobDataMap.put("subject", descriptor.getSubject());
			jobDataMap.put("messageBody", descriptor.getMessageBody());
			jobDataMap.put("to", descriptor.getTo());
			jobDataMap.put("cc", descriptor.getCc());
			jobDataMap.put("bcc", descriptor.getBcc());
			JobBuilder jb = oldJobDetail.getJobBuilder();
			JobDetail newJobDetail = jb.usingJobData(jobDataMap).storeDurably().build();
			scheduler.addJob(newJobDetail, true);
			log.info("Updated job with key - {}", newJobDetail.getKey());
			return;
		}
		log.warn("Could not find job with key - {}.{} to update", group, name);
	} catch (SchedulerException e) {
		log.error("Could not find job with key - {}.{} to update due to error - {}", group, name, e.getLocalizedMessage());
	}
}
 
開發者ID:juliuskrah,項目名稱:quartz-manager,代碼行數:22,代碼來源:EmailService.java

示例12: selectByWhere

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * 查詢所有定時任務
 * 
 * @param entity
 * @return Map
 * @throws SchedulerException
 */
@SuppressWarnings({ "rawtypes", "serial", "unchecked" })
@Override
public Object selectByWhere(T entity) throws SchedulerException {
	List<String> groups = scheduler.getJobGroupNames();
	List<HashMap<String, Object>> jobList = new ArrayList<HashMap<String, Object>>();
	for (String group : groups) {
		if (null != entity.getGroup() && !group.contains(entity.getGroup())) {
			continue;
		}
		Set<JobKey> jobKeys = scheduler.getJobKeys(new GroupMatcher(group,
				StringOperatorName.EQUALS) {
		});
		for (JobKey jobKey : jobKeys) {
			if (null != entity.getName()
					&& !jobKey.toString().contains(entity.getName())) {
				continue;
			}
			JobDetail jobDetail = scheduler.getJobDetail(jobKey);
			HashMap<String, Object> jobInfoMap = new HashMap<String, Object>();
			List<? extends Trigger> triggers = scheduler
					.getTriggersOfJob(jobKey);
			jobInfoMap.put("triggers", triggers);
			jobInfoMap.put("jobDetail", jobDetail);
			jobInfoMap.put("params",
					JSONArray.fromObject(jobDetail.getJobDataMap())
							.toString());
			jobInfoMap.put("type", "Kettle");
			jobList.add(jobInfoMap);
		}
	}
	Map<String, Object> map = new HashMap<String, Object>();
	map.put("jobList", jobList);
	map.put("scheduler", scheduler);
	return map;
}
 
開發者ID:jiangzongyao,項目名稱:kettle_support_kettle8.0,代碼行數:43,代碼來源:QuartzScheduleServiceImpl.java

示例13: refreshMetadata

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * Refresh metadata. Schedules the job to retrieve metadata.
 */
@PostConstruct
public void refreshMetadata() {
    final Thread thread = new Thread(new Runnable() {
        @Override
        public void run() {
            buildMetadataResolverAggregate();
        }
    });
    thread.start();

    final JobDetail job = JobBuilder.newJob(this.getClass())
            .withIdentity(this.getClass().getSimpleName().concat(UUID.randomUUID().toString())).build();
    final Trigger trigger = TriggerBuilder.newTrigger()
            .withIdentity(this.getClass().getSimpleName().concat(UUID.randomUUID().toString()))
            .withSchedule(SimpleScheduleBuilder.simpleSchedule()
                    .withIntervalInMinutes(this.refreshIntervalInMinutes)
                    .repeatForever()).build();

    try {
        scheduler.scheduleJob(job, trigger);
    } catch (final SchedulerException e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:hsj-xiaokang,項目名稱:springboot-shiro-cas-mybatis,代碼行數:28,代碼來源:StaticMetadataResolverAdapter.java

示例14: interrupt

import org.quartz.JobDetail; //導入依賴的package包/類
/**
 * Interrupt all instances of the identified InterruptableJob executing in 
 * this Scheduler instance.
 *  
 * <p>
 * This method is not cluster aware.  That is, it will only interrupt 
 * instances of the identified InterruptableJob currently executing in this 
 * Scheduler instance, not across the entire cluster.
 * </p>
 * 
 * @see org.quartz.core.RemotableQuartzScheduler#interrupt(JobKey)
 */
public boolean interrupt(JobKey jobKey) throws UnableToInterruptJobException {

    List<JobExecutionContext> jobs = getCurrentlyExecutingJobs();
    
    JobDetail jobDetail = null;
    Job job = null;
    
    boolean interrupted = false;
    
    for(JobExecutionContext jec : jobs) {
        jobDetail = jec.getJobDetail();
        if (jobKey.equals(jobDetail.getKey())) {
            job = jec.getJobInstance();
            if (job instanceof InterruptableJob) {
                ((InterruptableJob)job).interrupt();
                interrupted = true;
            } else {
                throw new UnableToInterruptJobException(
                        "Job " + jobDetail.getKey() +
                        " can not be interrupted, since it does not implement " +                        
                        InterruptableJob.class.getName());
            }
        }                        
    }
    
    return interrupted;
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:40,代碼來源:QuartzScheduler.java

示例15: notifySchedulerListenersJobAdded

import org.quartz.JobDetail; //導入依賴的package包/類
public void notifySchedulerListenersJobAdded(JobDetail jobDetail) {
    // build a list of all scheduler listeners that are to be notified...
    List<SchedulerListener> schedListeners = buildSchedulerListenerList();

    // notify all scheduler listeners
    for(SchedulerListener sl: schedListeners) {
        try {
            sl.jobAdded(jobDetail);
        } catch (Exception e) {
            getLog().error(
                    "Error while notifying SchedulerListener of JobAdded.",
                    e);
        }
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:16,代碼來源:QuartzScheduler.java


注:本文中的org.quartz.JobDetail類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。