Package org.opennms.netmgt.scheduler
Class LegacyScheduler
- java.lang.Object
- 
- org.opennms.netmgt.scheduler.LegacyScheduler
 
- 
- All Implemented Interfaces:
- java.lang.Runnable,- Fiber,- PausableFiber,- Scheduler,- ScheduleTimer,- Timer
 
 public class LegacyScheduler extends java.lang.Object implements java.lang.Runnable, PausableFiber, Scheduler This class implements a simple scheduler to ensure the polling occurs at the expected intervals. The scheduler employees a dynamic thread pool that adjust to the load until a maximum thread count is reached.- Author:
- Mike Davidson , Brian Weaver , OpenNMS
 
- 
- 
Field Summary- 
Fields inherited from interface org.opennms.core.fiber.FiberRUNNING, START_PENDING, STARTING, STATUS_NAMES, STOP_PENDING, STOPPED
 - 
Fields inherited from interface org.opennms.core.fiber.PausableFiberPAUSE_PENDING, PAUSED, RESUME_PENDING
 
- 
 - 
Constructor SummaryConstructors Constructor Description LegacyScheduler(java.lang.String parent, int maxSize)Constructs a new instance of the scheduler.LegacyScheduler(java.lang.String parent, int maxSize, float lowMark, float hiMark)Constructs a new instance of the scheduler.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description longgetCurrentTime()getCurrentTimejava.lang.StringgetName()Returns the name of this fiber.longgetNumTasksExecuted()Returns the total number of scheduled tasks (ReadyRunnables) that have been executed since the scheduler was initialized.java.util.concurrent.ExecutorServicegetRunner()Returns the pool of threads that are used to executed the runnable instances scheduled by the class' instance.intgetScheduled()Returns total number of elements currently scheduled.intgetStatus()getStatusvoidpause()pausevoidresume()resumevoidrun()The main method of the scheduler.voidschedule(long interval, ReadyRunnable runnable)schedulevoidschedule(ReadyRunnable runnable, long interval)This method is used to schedule a ready runnable in the system.voidstart()startvoidstop()stop
 
- 
- 
- 
Constructor Detail- 
LegacySchedulerpublic LegacyScheduler(java.lang.String parent, int maxSize)Constructs a new instance of the scheduler. The maximum number of executable threads is specified in the constructor. The executable threads are part of a runnable thread pool where the scheduled runnables are executed.- Parameters:
- parent- String prepended to "Scheduler" to create fiber name
- maxSize- The maximum size of the thread pool.
 
 - 
LegacySchedulerpublic LegacyScheduler(java.lang.String parent, int maxSize, float lowMark, float hiMark)Constructs a new instance of the scheduler. The maximum number of executable threads is specified in the constructor. The executable threads are part of a runnable thread pool where the scheduled runnables are executed.- Parameters:
- parent- String prepended to "Scheduler" to create fiber name
- maxSize- The maximum size of the thread pool.
- lowMark- The low water mark ratios of thread size to threads when threads are stopped.
- hiMark- The high water mark ratio of thread size to threads when threads are started.
 
 
- 
 - 
Method Detail- 
schedulepublic void schedule(ReadyRunnable runnable, long interval) This method is used to schedule a ready runnable in the system. The interval is used as the key for determining which queue to add the runnable.- Parameters:
- runnable- The element to run when interval expires.
- interval- The queue to add the runnable to.
- Throws:
- java.lang.RuntimeException- Thrown if an error occurs adding the element to the queue.
 
 - 
schedulepublic void schedule(long interval, ReadyRunnable runnable)schedule This method is used to schedule a ready runnable in the system. The interval is used as the key for determining which queue to add the runnable.- Specified by:
- schedulein interface- Scheduler
- Specified by:
- schedulein interface- ScheduleTimer
- Parameters:
- interval- a long.
- runnable- a- ReadyRunnableobject.
 
 - 
getCurrentTimepublic long getCurrentTime() getCurrentTime - Specified by:
- getCurrentTimein interface- Scheduler
- Specified by:
- getCurrentTimein interface- Timer
- Returns:
- a long.
 
 - 
startpublic void start() start 
 - 
stoppublic void stop() stop 
 - 
pausepublic void pause() pause - Specified by:
- pausein interface- PausableFiber
- Specified by:
- pausein interface- Scheduler
 
 - 
resumepublic void resume() resume - Specified by:
- resumein interface- PausableFiber
- Specified by:
- resumein interface- Scheduler
 
 - 
getStatuspublic int getStatus() getStatus 
 - 
getNamepublic java.lang.String getName() Returns the name of this fiber.
 - 
getScheduledpublic int getScheduled() Returns total number of elements currently scheduled.- Returns:
- the sum of all the elements in the various queues
 
 - 
getRunnerpublic java.util.concurrent.ExecutorService getRunner() Returns the pool of threads that are used to executed the runnable instances scheduled by the class' instance.- Returns:
- thread pool
 
 - 
runpublic void run() The main method of the scheduler. This method is responsible for checking the runnable queues for ready objects and then enqueuing them into the thread pool for execution.- Specified by:
- runin interface- java.lang.Runnable
 
 - 
getNumTasksExecutedpublic long getNumTasksExecuted() Returns the total number of scheduled tasks (ReadyRunnables) that have been executed since the scheduler was initialized.- Specified by:
- getNumTasksExecutedin interface- Scheduler
- Returns:
- the number of task executed
 
 
- 
 
-