/[projects]/android/TrainInfoService/src/dk/thoerup/traininfoservice/CircuitBreakerListener.java
ViewVC logotype

Contents of /android/TrainInfoService/src/dk/thoerup/traininfoservice/CircuitBreakerListener.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1308 - (show annotations) (download)
Tue Apr 19 15:46:22 2011 UTC (13 years ago) by torben
File size: 2525 byte(s)
Switch to dynamically added CircuitBreakerServlet
1 package dk.thoerup.traininfoservice;
2
3 import java.util.logging.Logger;
4
5 import javax.servlet.ServletContextEvent;
6 import javax.servlet.ServletContextListener;
7 import javax.servlet.ServletRegistration;
8 import javax.servlet.annotation.WebListener;
9
10 import dk.thoerup.circuitbreaker.AccountingCircuitBreaker;
11 import dk.thoerup.circuitbreaker.CircuitBreakerManager;
12 import dk.thoerup.circuitbreaker.LoggingCircuitBreaker;
13 import dk.thoerup.circuitbreaker.notification.CompositeNotifier;
14 import dk.thoerup.circuitbreaker.notification.JavaLogNotifier;
15 import dk.thoerup.circuitbreaker.notification.MailNotifier;
16
17
18 /**
19 * Application Lifecycle Listener implementation class JmxListener
20 *
21 */
22 @WebListener
23 public class CircuitBreakerListener implements ServletContextListener {
24
25 Logger logger = Logger.getLogger(CircuitBreakerListener.class.getName());
26
27 public CircuitBreakerListener() {
28 }
29
30 /**
31 * @see ServletContextListener#contextInitialized(ServletContextEvent)
32 */
33 public void contextInitialized(ServletContextEvent sce) {
34 logger.warning("Context Init");
35
36 int threshold = Integer.parseInt(sce.getServletContext().getInitParameter("banedk_threshold") );
37 int timeout = Integer.parseInt( sce.getServletContext().getInitParameter("banedk_timeout") );
38 CircuitBreakerManager mgr = CircuitBreakerManager.getManager();
39
40 CompositeNotifier notif = new CompositeNotifier();
41 notif.addNotifier( new JavaLogNotifier() );
42 notif.addNotifier( new MailNotifier("traininfo@t-hoerup.dk", "torben@t-hoerup.dk", "192.168.10.5") );
43
44
45 LoggingCircuitBreaker banedk = new LoggingCircuitBreaker("banedk", threshold, timeout);
46 banedk.setNotifier(notif);
47 mgr.addCircuitBreaker( banedk );
48
49
50 AccountingCircuitBreaker metro = new AccountingCircuitBreaker("metro", threshold, timeout);
51 metro.setNotifier(notif);
52 mgr.addCircuitBreaker( metro );
53
54
55 ServletRegistration.Dynamic dynconf = sce.getServletContext().addServlet("circuitbreaker", dk.thoerup.circuitbreaker.web.CircuitBreakerServletBase.class );
56 dynconf.addMapping("/CircuitBreakerServlet");
57 dynconf.setInitParameter("readonly", "0");
58
59 //JMXWrapper.registerAllCircuitBreakers();
60 }
61
62 /**
63 * @see ServletContextListener#contextDestroyed(ServletContextEvent)
64 */
65 public void contextDestroyed(ServletContextEvent sce) {
66 logger.warning("Context Destroyed");
67 CircuitBreakerManager.getManager().shutdown();
68
69 //JMXWrapper.unregisterAllCircuitBreakers();
70 }
71
72 }

  ViewVC Help
Powered by ViewVC 1.1.20