2 |
|
|
3 |
import java.util.Timer; |
import java.util.Timer; |
4 |
import java.util.TimerTask; |
import java.util.TimerTask; |
5 |
|
import java.util.logging.Logger; |
6 |
|
|
7 |
import javax.servlet.ServletContext; |
import javax.servlet.ServletContext; |
8 |
import javax.servlet.ServletContextEvent; |
import javax.servlet.ServletContextEvent; |
10 |
|
|
11 |
|
|
12 |
public class StatisticsListener implements ServletContextListener { |
public class StatisticsListener implements ServletContextListener { |
13 |
|
|
14 |
|
Logger log = Logger.getLogger(StatisticsListener.class.getName()); |
15 |
|
|
16 |
Timer timer = null; |
Timer timer = null; |
17 |
int update_interval; |
int update_interval; |
19 |
public void contextInitialized(ServletContextEvent sce) { |
public void contextInitialized(ServletContextEvent sce) { |
20 |
|
|
21 |
update_interval = getUpdateInterval( sce.getServletContext() ); |
update_interval = getUpdateInterval( sce.getServletContext() ); |
22 |
|
|
23 |
|
log.info("StatisticsListener::contextInit called update_interval=" + update_interval); |
24 |
|
|
25 |
if ( update_interval > 0 ) { |
if ( update_interval > 0 ) { |
26 |
timer = new Timer(); |
timer = new Timer(); |
27 |
|
|
38 |
|
|
39 |
|
|
40 |
public void contextDestroyed(ServletContextEvent sce) { |
public void contextDestroyed(ServletContextEvent sce) { |
41 |
|
log.info("StatisticsListener::contextDestroyed"); |
42 |
if ( update_interval > 0 ) { |
if ( update_interval > 0 ) { |
43 |
timer.cancel(); |
timer.cancel(); |
44 |
Statistics.getInstance().saveStats(); |
Statistics.getInstance().saveStats(); |