Author: tabish
Date: Fri Sep 23 18:48:19 2011
New Revision: 1174951

URL: http://svn.apache.org/viewvc?rev=1174951&view=rev
Log:
fix for: https://issues.apache.org/jira/browse/AMQ-3031 

Don't use the scheduleAtFixedRate method in our scheduler as we
don't really have a need for real time task execution, just use
the fixed delay scheduler so that jobs don't stack up.

Modified:
    
activemq/trunk/activemq-core/src/main/java/org/apache/activemq/thread/Scheduler.java

Modified: 
activemq/trunk/activemq-core/src/main/java/org/apache/activemq/thread/Scheduler.java
URL: 
http://svn.apache.org/viewvc/activemq/trunk/activemq-core/src/main/java/org/apache/activemq/thread/Scheduler.java?rev=1174951&r1=1174950&r2=1174951&view=diff
==============================================================================
--- 
activemq/trunk/activemq-core/src/main/java/org/apache/activemq/thread/Scheduler.java
 (original)
+++ 
activemq/trunk/activemq-core/src/main/java/org/apache/activemq/thread/Scheduler.java
 Fri Sep 23 18:48:19 2011
@@ -23,25 +23,25 @@ import org.apache.activemq.util.ServiceS
 import org.apache.activemq.util.ServiceSupport;
 
 /**
- * 
+ *
  */
-public final class Scheduler extends ServiceSupport { 
+public final class Scheduler extends ServiceSupport {
     private final String name;
-       private Timer timer;
+    private Timer timer;
     private final HashMap<Runnable, TimerTask> timerTasks = new 
HashMap<Runnable, TimerTask>();
-    
+
     public Scheduler (String name) {
         this.name = name;
     }
-        
+
     public void executePeriodically(final Runnable task, long period) {
-       TimerTask timerTask = new SchedulerTimerTask(task);
-        timer.scheduleAtFixedRate(timerTask, period, period);
+        TimerTask timerTask = new SchedulerTimerTask(task);
+        timer.schedule(timerTask, period, period);
         timerTasks.put(task, timerTask);
     }
 
     /*
-     * execute on rough schedual based on termination of last execution. There 
is no
+     * execute on rough schedule based on termination of last execution. There 
is no
      * compensation (two runs in quick succession) for delays
      */
     public synchronized void schedualPeriodically(final Runnable task, long 
period) {
@@ -49,9 +49,9 @@ public final class Scheduler extends Ser
         timer.schedule(timerTask, period, period);
         timerTasks.put(task, timerTask);
     }
-    
+
     public synchronized void cancel(Runnable task) {
-       TimerTask ticket = timerTasks.remove(task);
+        TimerTask ticket = timerTasks.remove(task);
         if (ticket != null) {
             ticket.cancel();
             timer.purge();//remove cancelled TimerTasks
@@ -59,10 +59,10 @@ public final class Scheduler extends Ser
     }
 
     public synchronized void executeAfterDelay(final Runnable task, long 
redeliveryDelay) {
-       TimerTask timerTask = new SchedulerTimerTask(task);
+        TimerTask timerTask = new SchedulerTimerTask(task);
         timer.schedule(timerTask, redeliveryDelay);
     }
-    
+
     public void shutdown() {
         timer.cancel();
     }
@@ -70,7 +70,7 @@ public final class Scheduler extends Ser
     @Override
     protected synchronized void doStart() throws Exception {
         this.timer = new Timer(name, true);
-        
+
     }
 
     @Override
@@ -78,7 +78,7 @@ public final class Scheduler extends Ser
        if (this.timer != null) {
            this.timer.cancel();
        }
-        
+
     }
 
     public String getName() {


Reply via email to