00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031 package org.objectweb.proactive.loadbalancing;
00032
00033 import java.util.Random;
00034
00035 import org.apache.log4j.Logger;
00036 import org.objectweb.proactive.ProActiveInternalObject;
00037 import org.objectweb.proactive.core.util.log.Loggers;
00038 import org.objectweb.proactive.core.util.log.ProActiveLogger;
00039 import org.objectweb.proactive.loadbalancing.metrics.Metric;
00040
00041
00055 public class LoadMonitor implements Runnable,ProActiveInternalObject {
00056 static Logger logger = ProActiveLogger.getLogger(Loggers.LOAD_BALANCING);
00057
00058 protected LoadBalancer lb;
00059 protected Metric metric;
00060
00061 public LoadMonitor(LoadBalancer lb, Metric metric) {
00062 this.lb = lb;
00063 this.metric = metric;
00064
00065 }
00066
00067 public synchronized void killMePlease() {
00068 Thread.currentThread().interrupt();
00069 }
00070
00071 public void run() {
00072 Random r = new Random();
00073 do {
00074 this.metric.takeDecision(lb);
00075 try {
00076 double sl;
00077 sl = LoadBalancingConstants.UPDATE_TIME * r.nextDouble();
00078
00079
00080
00081
00082
00083
00084 Thread.sleep(Math.round(sl));
00085 } catch (InterruptedException interruptedexception) {
00086 }
00087 } while (true);
00088 }
00089 }