KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > openlaszlo > iv > flash > servlet > StatManager


1 /*
2  * $Id: StatManager.java,v 1.3 2002/02/24 02:10:19 skavish Exp $
3  *
4  * ==========================================================================
5  *
6  * The JGenerator Software License, Version 1.0
7  *
8  * Copyright (c) 2000 Dmitry Skavish (skavish@usa.net). All rights reserved.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright
14  * notice, this list of conditions and the following disclaimer.
15  *
16  * 2. Redistributions in binary form must reproduce the above copyright
17  * notice, this list of conditions and the following disclaimer in
18  * the documentation and/or other materials provided with the
19  * distribution.
20  *
21  * 3. The end-user documentation included with the redistribution, if
22  * any, must include the following acknowlegement:
23  * "This product includes software developed by Dmitry Skavish
24  * (skavish@usa.net, http://www.flashgap.com/)."
25  * Alternately, this acknowlegement may appear in the software itself,
26  * if and wherever such third-party acknowlegements normally appear.
27  *
28  * 4. The name "The JGenerator" must not be used to endorse or promote
29  * products derived from this software without prior written permission.
30  * For written permission, please contact skavish@usa.net.
31  *
32  * 5. Products derived from this software may not be called "The JGenerator"
33  * nor may "The JGenerator" appear in their names without prior written
34  * permission of Dmitry Skavish.
35  *
36  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39  * DISCLAIMED. IN NO EVENT SHALL DMITRY SKAVISH OR THE OTHER
40  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47  * SUCH DAMAGE.
48  *
49  */

50
51 package org.openlaszlo.iv.flash.servlet;
52
53 import java.io.*;
54 import java.net.*;
55 import java.util.*;
56
57 import javax.servlet.*;
58 import javax.servlet.http.*;
59
60 import org.openlaszlo.iv.flash.util.*;
61 import org.openlaszlo.iv.flash.cache.*;
62
63
64 /**
65  * Generator servlet statistic
66  */

67 public class StatManager {
68
69     static class StatDaemon extends Thread JavaDoc {
70         public StatDaemon() {}
71
72         public void run() {
73             for(;;) {
74                 Date date = new Date( System.currentTimeMillis() );
75                 int day = date.getDay();
76                 try {
77                     Thread.sleep(1000*60); // sleep for 1 minute
78
} catch( InterruptedException JavaDoc e ) {
79                     continue;
80                 }
81                 long now = System.currentTimeMillis();
82                 today.setEndTime( now );
83                 save();
84                 date = new Date( now );
85                 if( day != date.getDay() ) {
86                     synchronized( StatManager.class ) {
87                         today = new StatUnit( now );
88                         statistic.addElement(today);
89                     }
90                 }
91             }
92         }
93     }
94
95     private static String JavaDoc statFileName;
96     private static StatUnit sinceStartup;
97     private static StatUnit today;
98     private static Vector statistic;
99     private static StatDaemon statDaemon;
100
101     private static void save() {
102         try {
103             FileOutputStream out = new FileOutputStream( statFileName );
104             ObjectOutputStream p = new ObjectOutputStream( out );
105             p.writeObject( statistic );
106             p.flush();
107             out.close();
108         } catch( IOException e ) {
109             Log.logRB(e);
110         }
111     }
112
113     private synchronized static void load() {
114         try {
115             FileInputStream in = new FileInputStream( statFileName );
116             ObjectInputStream p = new ObjectInputStream( in );
117             statistic = (Vector) p.readObject();
118             p.close();
119             in.close();
120         } catch( FileNotFoundException e ) {
121             statistic = new Vector();
122         } catch( Exception JavaDoc e ) {
123             Log.logRB(e);
124             statistic = new Vector();
125         }
126         // find today's stat
127
today = null;
128         Date date = new Date( System.currentTimeMillis() );
129         int tday = date.getDay();
130         for( int i=0; i<statistic.size(); i++ ) {
131             StatUnit unit = (StatUnit) statistic.elementAt(i);
132             date = new Date( unit.getStartTime() );
133             if( tday == date.getDay() ) {
134                 today = unit;
135                 break;
136             }
137         }
138         if( today == null ) {
139             today = new StatUnit( System.currentTimeMillis() );
140             statistic.addElement( today );
141         }
142     }
143
144     public static void init() {
145         sinceStartup = new StatUnit( System.currentTimeMillis() );
146         statFileName = PropertyManager.getProperty("org.openlaszlo.iv.flash.statFileName","logs/stat");
147         if( statFileName != null ) {
148             File statFile = Util.getSysFile( statFileName );
149             statFileName = statFile.getAbsolutePath();
150         }
151         load();
152         statDaemon = new StatDaemon();
153         statDaemon.start();
154     }
155
156     public static StatUnit getSinceStartup() {
157         return sinceStartup;
158     }
159
160     public static Vector getStatistic() {
161         return statistic;
162     }
163
164     /**
165      * Add statistic for the given request
166      */

167     public static void addRequest( String JavaDoc fileName, int size, long processTime, long totalTime ) {
168         sinceStartup.addRequest(fileName, size, processTime, totalTime);
169         today.addRequest(fileName, size, processTime, totalTime);
170     }
171 }
172
173
Popular Tags