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


Java GroupMatcher類代碼示例

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


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

示例1: getAllJob

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * 獲取所有計劃中的任務列表
 * 
 * @return
 * @throws SchedulerException
 */
public List<ScheduleJob> getAllJob() throws SchedulerException {
    Scheduler scheduler = schedulerFactoryBean.getScheduler();
    GroupMatcher<JobKey> matcher = GroupMatcher.anyJobGroup();
    Set<JobKey> jobKeys = scheduler.getJobKeys(matcher);
    List<ScheduleJob> jobList = new ArrayList<ScheduleJob>();
    for (JobKey jobKey : jobKeys) {
        List<? extends Trigger> triggers = scheduler.getTriggersOfJob(jobKey);
        for (Trigger trigger : triggers) {
            ScheduleJob job = new ScheduleJob();
            job.setName(jobKey.getName());
            job.setGroup(jobKey.getGroup());
            job.setDescription("觸發器:" + trigger.getKey());
            Trigger.TriggerState triggerState = scheduler.getTriggerState(trigger.getKey());
            job.setStatus(triggerState.name());
            if (trigger instanceof CronTrigger) {
                CronTrigger cronTrigger = (CronTrigger) trigger;
                String cronExpression = cronTrigger.getCronExpression();
                job.setCron(cronExpression);
            }
            jobList.add(job);
        }
    }
    return jobList;
}
 
開發者ID:Zigin,項目名稱:MonitorPlatform,代碼行數:31,代碼來源:JobConfigService.java

示例2: getScheduledJobIds

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
@Override
@SuppressWarnings("unchecked")
public Set<String> getScheduledJobIds() throws KairosDBException
{
	Set<String> scheduledJobs = new HashSet<String>();
	try
	{
		for (String groupName : scheduler.getJobGroupNames())
		{
			for (JobKey jobKey : scheduler.getJobKeys(GroupMatcher.jobGroupEquals(groupName)))
			{
				scheduledJobs.add(jobKey.getName());
			}
		}
	}
	catch (SchedulerException e)
	{
		throw new KairosDBException("Could not get scheduled jobs." + e);
	}

	return scheduledJobs;
}
 
開發者ID:quqiangsheng,項目名稱:abhot,代碼行數:23,代碼來源:KairosDBSchedulerImpl.java

示例3: pauseJobs

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * <p>
 * Calls the equivalent method on the 'proxied' <code>QuartzScheduler</code>,
 * passing the <code>SchedulingContext</code> associated with this
 * instance.
 * </p>
 */
public void pauseJobs(GroupMatcher<JobKey> matcher) throws SchedulerException {
    String operation = null;
    switch (matcher.getCompareWithOperator()) {
        case EQUALS:
            operation = "pauseJobGroup";
            break;
        case STARTS_WITH:
            operation = "pauseJobsStartingWith";
            break;
        case ENDS_WITH:
            operation = "pauseJobsEndingWith";
            break;
        case CONTAINS:
            operation = "pauseJobsContaining";
        case ANYTHING:
            operation = "pauseJobsAll";
    }

    invoke(
            operation,
            new Object[] { matcher.getCompareToValue() },
            new String[] { String.class.getName() });
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:31,代碼來源:RemoteMBeanScheduler.java

示例4: resumeTriggers

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * <p>
 * Resume (un-pause) all of the <code>{@link Trigger}s</code> in the given group.
 * </p>
 * <p>
 * If any <code>Trigger</code> missed one or more fire-times, then the <code>Trigger</code>'s misfire instruction will
 * be applied.
 * </p>
 */
@Override
public Collection<String> resumeTriggers(GroupMatcher<TriggerKey> matcher) throws JobPersistenceException {
  Collection<String> groups = new HashSet<String>();
  lock();
  try {
    Set<TriggerKey> triggerKeys = getTriggerKeys(matcher);

    for (TriggerKey triggerKey : triggerKeys) {
      TriggerWrapper tw = triggerFacade.get(triggerKey);
      if (tw != null) {
        String jobGroup = tw.getJobKey().getGroup();

        if (jobFacade.pausedGroupsContain(jobGroup)) {
          continue;
        }
        groups.add(triggerKey.getGroup());
      }
      resumeTrigger(triggerKey);
    }
    triggerFacade.removeAllPausedGroups(groups);
  } finally {
    unlock();
  }
  return groups;
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:35,代碼來源:DefaultClusteredJobStore.java

示例5: resumeAll

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * <p>
 * Resume (un-pause) all triggers - equivalent of calling <code>resumeTriggerGroup(group)</code> on every group.
 * </p>
 * <p>
 * If any <code>Trigger</code> missed one or more fire-times, then the <code>Trigger</code>'s misfire instruction will
 * be applied.
 * </p>
 * 
 * @see #pauseAll()
 */
@Override
public void resumeAll() throws JobPersistenceException {

  lock();
  try {
    jobFacade.clearPausedJobGroups();
    List<String> names = getTriggerGroupNames();

    for (String name : names) {
      resumeTriggers(GroupMatcher.triggerGroupEquals(name));
    }
  } finally {
    unlock();
  }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:27,代碼來源:DefaultClusteredJobStore.java

示例6: resumeTriggers

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * <p>
 * Resume (un-pause) all of the <code>{@link Trigger}s</code> in the
 * given group.
 * </p>
 *
 * <p>
 * If any <code>Trigger</code> missed one or more fire-times, then the
 * <code>Trigger</code>'s misfire instruction will be applied.
 * </p>
 *
 */
public List<String> resumeTriggers(GroupMatcher<TriggerKey> matcher) {
    Set<String> groups = new HashSet<String>();

    synchronized (lock) {
        Set<TriggerKey> keys = getTriggerKeys(matcher);

        for (TriggerKey triggerKey: keys) {
            groups.add(triggerKey.getGroup());
            if(triggersByKey.get(triggerKey) != null) {
                String jobGroup = triggersByKey.get(triggerKey).jobKey.getGroup();
                if(pausedJobGroups.contains(jobGroup)) {
                    continue;
                }
            }
            resumeTrigger(triggerKey);
        }
        for (String group : groups) {
            pausedTriggerGroups.remove(group);
        }
    }

    return new ArrayList<String>(groups);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:36,代碼來源:RAMJobStore.java

示例7: getTaskList

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * Returns all Jobs from the Scheduler.
 *
 * @return all Jobs from the Scheduler.
 * @throws FrameworkException    in case any internal error occurs.
 * @throws ApplicationExceptions Indicates application error(s).
 */
private List<ScheduledTask> getTaskList() throws FrameworkException,
        ApplicationExceptions {
  List<ScheduledTask> tasks = null;
  try {
    final List<String> names = scheduler.getJobGroupNames();
    if (names != null && 0 < names.size()) {
      tasks = new LinkedList<ScheduledTask>();
      for (final String groupName : names) {
        for (final JobKey jobKey : scheduler.getJobKeys(GroupMatcher
                .jobGroupEquals(groupName))) {
          final JobDetail jobDetail = scheduler.getJobDetail(jobKey);
          final List<? extends Trigger> triggers = scheduler
                  .getTriggersOfJob(jobKey);
          final ScheduledTask task = jobAndTriggerToTask(jobDetail, triggers);
          tasks.add(task);
        }
      }
    }
    return tasks;
  } catch (SchedulerException e) {
    LOGGER.error("Error in retriving Jobs from the Scheduler", e);
    throw new JaffaSchedulerFrameworkException(
            JaffaSchedulerFrameworkException.TASK_RETRIEVE_ERROR, null, e);
  }
}
 
開發者ID:jaffa-projects,項目名稱:jaffa-framework,代碼行數:33,代碼來源:QuartzSchedulerHelper.java

示例8: pauseAll

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * <p>
 * Pause all triggers - equivalent of calling <code>pauseTriggerGroup(group)</code>
 * on every group.
 * </p>
 * 
 * <p>
 * When <code>resumeAll()</code> is called (to un-pause), trigger misfire
 * instructions WILL be applied.
 * </p>
 * 
 * @see #resumeAll(Connection)
 * @see #pauseTriggerGroup(java.sql.Connection, org.quartz.impl.matchers.GroupMatcher)
 */
public void pauseAll(Connection conn)
    throws JobPersistenceException {

    List<String> names = getTriggerGroupNames(conn);

    for (String name: names) {
        pauseTriggerGroup(conn, GroupMatcher.triggerGroupEquals(name));
    }

    try {
        if (!getDelegate().isTriggerGroupPaused(conn, ALL_GROUPS_PAUSED)) {
            getDelegate().insertPausedTriggerGroup(conn, ALL_GROUPS_PAUSED);
        }

    } catch (SQLException e) {
        throw new JobPersistenceException(
                "Couldn't pause all trigger groups: " + e.getMessage(), e);
    }

}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:35,代碼來源:JobStoreSupport.java

示例9: resumeAll

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * protected
 * <p>
 * Resume (un-pause) all triggers - equivalent of calling <code>resumeTriggerGroup(group)</code>
 * on every group.
 * </p>
 * 
 * <p>
 * If any <code>Trigger</code> missed one or more fire-times, then the
 * <code>Trigger</code>'s misfire instruction will be applied.
 * </p>
 * 
 * @see #pauseAll(Connection)
 */
public void resumeAll(Connection conn)
    throws JobPersistenceException {

    List<String> names = getTriggerGroupNames(conn);

    for (String name: names) {
        resumeTriggerGroup(conn, GroupMatcher.triggerGroupEquals(name));
    }

    try {
        getDelegate().deletePausedTriggerGroup(conn, ALL_GROUPS_PAUSED);
    } catch (SQLException e) {
        throw new JobPersistenceException(
                "Couldn't resume all trigger groups: " + e.getMessage(), e);
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:31,代碼來源:JobStoreSupport.java

示例10: updateTriggerGroupStateFromOtherState

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
/**
 * <p>
 * Update all of the triggers of the given group to the given new state, if
 * they are in the given old state.
 * </p>
 * 
 * @param conn
 *          the DB connection
 * @param matcher
 *          the groupMatcher to evaluate the triggers against
 * @param newState
 *          the new state for the trigger group
 * @param oldState
 *          the old state the triggers must be in
 * @return int the number of rows updated
 * @throws SQLException
 */
public int updateTriggerGroupStateFromOtherState(Connection conn,
        GroupMatcher<TriggerKey> matcher, String newState, String oldState)
    throws SQLException {
    PreparedStatement ps = null;

    try {
        ps = conn
                .prepareStatement(rtp(UPDATE_TRIGGER_GROUP_STATE_FROM_STATE));
        ps.setString(1, newState);
        ps.setString(2, toSqlLikeClause(matcher));
        ps.setString(3, oldState);

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

示例11: selectTriggerGroups

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
public List<String> selectTriggerGroups(Connection conn, GroupMatcher<TriggerKey> matcher) throws SQLException {
    PreparedStatement ps = null;
    ResultSet rs = null;

    try {
        ps = conn.prepareStatement(rtp(SELECT_TRIGGER_GROUPS_FILTERED));
        ps.setString(1, toSqlLikeClause(matcher));
        rs = ps.executeQuery();

        LinkedList<String> list = new LinkedList<String>();
        while (rs.next()) {
            list.add(rs.getString(1));
        }

        return list;
    } finally {
        closeResultSet(rs);
        closeStatement(ps);
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:21,代碼來源:StdJDBCDelegate.java

示例12: getAllJobList

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
public List<ScheduleJob> getAllJobList(){  
    List<ScheduleJob> jobList = new ArrayList<>();  
    try {  
        GroupMatcher<JobKey> matcher = GroupMatcher.anyJobGroup();  
        Set<JobKey> jobKeySet = scheduler.getJobKeys(matcher);  
        for (JobKey jobKey : jobKeySet){  
            List<? extends Trigger> triggers = scheduler.getTriggersOfJob(jobKey);  
            for (Trigger trigger : triggers){  
                ScheduleJob scheduleJob = new ScheduleJob();  
                this.wrapScheduleJob(scheduleJob,scheduler,jobKey,trigger);  
                jobList.add(scheduleJob);  
            }  
        }  
    } catch (SchedulerException e) {  
    	e.printStackTrace();   
    }  
    return jobList;  
}
 
開發者ID:jiwenxing,項目名稱:springboot-quartz,代碼行數:19,代碼來源:ScheduleJobService.java

示例13: getTriggersForGroup

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
private List<TriggerDefinition> getTriggersForGroup(GroupMatcher<TriggerKey> groupMatcher) {
    try {
        return scheduler.getTriggerKeys(groupMatcher).stream()
                        .map(this::getTriggerSafe)
                        .filter(trigger -> trigger != null)
                        .map(quartzToCronyxSelector::convert)
                        .map(this::enhanceTriggerDefinition)
                        .collect(Collectors.toList());
    } catch (SchedulerException e) {
        throw new SchedulingException(e);
    }
}
 
開發者ID:taboola,項目名稱:taboola-cronyx,代碼行數:13,代碼來源:QuartzSchedulerServiceImpl.java

示例14: getJobNames

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
public List<String> getJobNames(String groupName) throws Exception {
    try {
        List<String> jobNames = new ArrayList<String>();
        for(JobKey key: scheduler.getJobKeys(GroupMatcher.jobGroupEquals(groupName))) {
            jobNames.add(key.getName());
        }
        return jobNames;
    } catch (Exception e) {
        throw newPlainException(e);
    }
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:12,代碼來源:QuartzSchedulerMBeanImpl.java

示例15: getAllJobDetail

import org.quartz.impl.matchers.GroupMatcher; //導入依賴的package包/類
public List<TaskScheduled> getAllJobDetail() {
    List<TaskScheduled> result = new LinkedList<TaskScheduled>();
    try {
        GroupMatcher<JobKey> matcher = GroupMatcher.jobGroupContains("");
        Set<JobKey> jobKeys = scheduler.getJobKeys(matcher);
        for (JobKey jobKey : jobKeys) {
            JobDetail jobDetail = scheduler.getJobDetail(jobKey);
            List<? extends Trigger> triggers = scheduler.getTriggersOfJob(jobKey);
            for (Trigger trigger : triggers) {
                TaskScheduled job = new TaskScheduled();
                job.setTaskName(jobKey.getName());
                job.setTaskGroup(jobKey.getGroup());
                TriggerState triggerState = scheduler.getTriggerState(trigger.getKey());
                job.setStatus(triggerState.name());
                if (trigger instanceof CronTrigger) {
                    CronTrigger cronTrigger = (CronTrigger)trigger;
                    String cronExpression = cronTrigger.getCronExpression();
                    job.setTaskCron(cronExpression);
                }
                job.setPreviousFireTime(trigger.getPreviousFireTime());
                job.setNextFireTime(trigger.getNextFireTime());
                JobDataMap jobDataMap = trigger.getJobDataMap();
                job.setTaskType(jobDataMap.getString("taskType"));
                job.setTargetSystem(jobDataMap.getString("targetSystem"));
                job.setTargetObject(jobDataMap.getString("targetObject"));
                job.setTargetMethod(jobDataMap.getString("targetMethod"));
                job.setContactName(jobDataMap.getString("contactName"));
                job.setContactEmail(jobDataMap.getString("contactEmail"));
                job.setTaskDesc(jobDetail.getDescription());
                String jobClass = jobDetail.getJobClass().getSimpleName();
                if (jobClass.equals("StatefulJob")) {
                    job.setJobType("statefulJob");
                } else if (jobClass.equals("DefaultJob")) {
                    job.setJobType("job");
                }
                result.add(job);
            }
        }
    } catch (Exception e) {
        logger.error("Try to load All JobDetail cause error : ", e);
    }
    return result;
}
 
開發者ID:guokezheng,項目名稱:automat,代碼行數:44,代碼來源:SchedulerManager.java


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