All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.quartz.core.SampledStatisticsImpl Maven / Gradle / Ivy

package org.quartz.core;

import java.util.Timer;

import org.quartz.JobDetail;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.JobListener;
import org.quartz.SchedulerListener;
import org.quartz.Trigger;
import org.quartz.listeners.SchedulerListenerSupport;
import org.quartz.utils.counter.CounterConfig;
import org.quartz.utils.counter.CounterManager;
import org.quartz.utils.counter.CounterManagerImpl;
import org.quartz.utils.counter.sampled.SampledCounter;
import org.quartz.utils.counter.sampled.SampledCounterConfig;
import org.quartz.utils.counter.sampled.SampledRateCounterConfig;

public class SampledStatisticsImpl extends SchedulerListenerSupport implements SampledStatistics, JobListener, SchedulerListener {
	@SuppressWarnings("unused")
  private final QuartzScheduler scheduler;
	
	private static final String NAME = "QuartzSampledStatistics";
	
    private static final int DEFAULT_HISTORY_SIZE = 30;
    private static final int DEFAULT_INTERVAL_SECS = 1;
    private final static SampledCounterConfig DEFAULT_SAMPLED_COUNTER_CONFIG = new SampledCounterConfig(DEFAULT_INTERVAL_SECS,
            DEFAULT_HISTORY_SIZE, true, 0L);
    @SuppressWarnings("unused")
    private final static SampledRateCounterConfig DEFAULT_SAMPLED_RATE_COUNTER_CONFIG = new SampledRateCounterConfig(DEFAULT_INTERVAL_SECS,
            DEFAULT_HISTORY_SIZE, true);

    private volatile CounterManager counterManager;
    private final SampledCounter jobsScheduledCount;
    private final SampledCounter jobsExecutingCount;
    private final SampledCounter jobsCompletedCount;
	
	SampledStatisticsImpl(QuartzScheduler scheduler) {
		this.scheduler = scheduler;
		
        counterManager = new CounterManagerImpl(new Timer(NAME+"Timer"));
        jobsScheduledCount = createSampledCounter(DEFAULT_SAMPLED_COUNTER_CONFIG);
        jobsExecutingCount = createSampledCounter(DEFAULT_SAMPLED_COUNTER_CONFIG);
        jobsCompletedCount = createSampledCounter(DEFAULT_SAMPLED_COUNTER_CONFIG);
        
        scheduler.addInternalSchedulerListener(this);
        scheduler.addInternalJobListener(this);
	}
	
	public void shutdown() {
	    counterManager.shutdown(true);
	}
	
    private SampledCounter createSampledCounter(CounterConfig defaultCounterConfig) {
        return (SampledCounter) counterManager.createCounter(defaultCounterConfig);
    }
	
    /**
     * Clears the collected statistics. Resets all counters to zero
     */
    public void clearStatistics() {
    	jobsScheduledCount.getAndReset();
    	jobsExecutingCount.getAndReset();
    	jobsCompletedCount.getAndReset();
    }
    
	public long getJobsCompletedMostRecentSample() {
        return jobsCompletedCount.getMostRecentSample().getCounterValue();
	}

	public long getJobsExecutingMostRecentSample() {
        return jobsExecutingCount.getMostRecentSample().getCounterValue();
	}

	public long getJobsScheduledMostRecentSample() {
        return jobsScheduledCount.getMostRecentSample().getCounterValue();
	}

	public String getName() {
		return NAME;
	}

    @Override
    public void jobScheduled(Trigger trigger) {
    	jobsScheduledCount.increment();
    }
	
	public void jobExecutionVetoed(JobExecutionContext context) {
		/**/
	}

	public void jobToBeExecuted(JobExecutionContext context) {
		jobsExecutingCount.increment();
	}

	public void jobWasExecuted(JobExecutionContext context,
			JobExecutionException jobException) {
		jobsCompletedCount.increment();
	}

	@Override
    public void jobAdded(JobDetail jobDetail) {
		/**/
	}

	public void jobDeleted(String jobName, String groupName) {
		/**/
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy