00001 /* 00002 * ################################################################ 00003 * 00004 * ProActive: The Java(TM) library for Parallel, Distributed, 00005 * Concurrent computing with Security and Mobility 00006 * 00007 * Copyright (C) 1997-2007 INRIA/University of Nice-Sophia Antipolis 00008 * Contact: proactive@objectweb.org 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2.1 of the License, or any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 * USA 00024 * 00025 * Initial developer(s): The ProActive Team 00026 * http://www.inria.fr/oasis/ProActive/contacts.html 00027 * Contributor(s): 00028 * 00029 * ################################################################ 00030 */ 00031 package org.objectweb.proactive.calcium.monitor; 00032 00033 import org.objectweb.proactive.calcium.Calcium; 00034 import org.objectweb.proactive.calcium.statistics.StatsGlobal; 00035 00036 00037 public class SimpleLogMonitor implements Monitor { 00038 Calcium calcium; 00039 int frequency; 00040 boolean stoped; 00041 MonitoringThread thread; 00042 00043 public SimpleLogMonitor(Calcium calcium, int frequency) { 00044 this.calcium = calcium; 00045 this.frequency = frequency; 00046 this.stoped = true; 00047 thread=null; 00048 } 00049 00050 public synchronized void stop() { 00051 stoped = true; 00052 thread.interrupt(); 00053 thread = null; 00054 } 00055 00056 public synchronized void start() { 00057 if(thread!=null) return; 00058 stoped = false; 00059 thread= new MonitoringThread(); 00060 thread.start(); 00061 00062 } 00063 00064 public synchronized boolean isStoped() { 00065 return stoped; 00066 } 00067 00068 class MonitoringThread extends Thread{ 00069 00070 public void run() { 00071 while (!isStoped()) { 00072 try { 00073 Thread.sleep(frequency * 1000); 00074 } catch (InterruptedException e) { 00075 //e.printStackTrace(); 00076 return; 00077 } 00078 00079 StatsGlobal stats = calcium.getStatsGlobal(); 00080 System.out.println(stats); 00081 } 00082 } 00083 } 00084 }