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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 425 by torben, Thu Oct 8 20:46:40 2009 UTC revision 1399 by torben, Thu Apr 28 16:55:52 2011 UTC
# Line 4  import java.util.logging.Logger; Line 4  import java.util.logging.Logger;
4    
5  import javax.servlet.ServletContextEvent;  import javax.servlet.ServletContextEvent;
6  import javax.servlet.ServletContextListener;  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    
 import dk.thoerup.curcuitbreaker.AccountingCircuitBreaker;  
 import dk.thoerup.curcuitbreaker.CircuitBreakerManager;  
 import dk.thoerup.curcuitbreaker.jmx.JMXWrapper;  
 import dk.thoerup.curcuitbreaker.notification.JavaLogNotifier;  
17    
18  /**  /**
19   * Application Lifecycle Listener implementation class JmxListener   * Application Lifecycle Listener implementation class JmxListener
20   *   *
21   */   */
22    @WebListener
23  public class CircuitBreakerListener implements ServletContextListener {  public class CircuitBreakerListener implements ServletContextListener {
24    
25          Logger logger = Logger.getLogger(CircuitBreakerListener.class.getName());          Logger logger = Logger.getLogger(CircuitBreakerListener.class.getName());
# Line 27  public class CircuitBreakerListener impl Line 33  public class CircuitBreakerListener impl
33      public void contextInitialized(ServletContextEvent sce) {      public void contextInitialized(ServletContextEvent sce) {
34          logger.warning("Context Init");          logger.warning("Context Init");
35                    
36            TraininfoSettings settings = SettingsListener.loadSettings( sce.getServletContext() );
37    
38          CircuitBreakerManager mgr = CircuitBreakerManager.getManager();          CircuitBreakerManager mgr = CircuitBreakerManager.getManager();
39                    
40                  AccountingCircuitBreaker banedk = new AccountingCircuitBreaker("banedk", 5, 20000);                  CompositeNotifier notif = new CompositeNotifier();
41                  banedk.setNotifier( new JavaLogNotifier() );                  notif.addNotifier( new JavaLogNotifier() );
42                  mgr.addCircuitBreaker( banedk );                                  
43                    //only send mail on prod server
44                    if (sce.getServletContext().getRealPath("/").startsWith("/home/app/")  ) {              
45                            notif.addNotifier( new MailNotifier("traininfo@t-hoerup.dk", "torben@t-hoerup.dk", "192.168.10.5") );
46            }
47            
48                    LoggingCircuitBreaker banedk = new LoggingCircuitBreaker("banedk", settings);
49                    banedk.setNotifier(notif);
50                    mgr.addCircuitBreaker( banedk );
51                    
52                                    
53                  JMXWrapper.registerAllCircuitBreakers();                  AccountingCircuitBreaker metro = new AccountingCircuitBreaker("metro", settings);
54                    metro.setNotifier(notif);
55                    mgr.addCircuitBreaker( metro );
56                    
57                    
58                    ServletRegistration.Dynamic dynconf = sce.getServletContext().addServlet("circuitbreaker", dk.thoerup.circuitbreaker.web.CircuitBreakerServletBase.class );
59                    dynconf.addMapping("/CircuitBreakerServlet");
60                    dynconf.setInitParameter("readonly", "0");
61                    
62                    //JMXWrapper.registerAllCircuitBreakers();
63      }      }
64    
65          /**          /**
# Line 41  public class CircuitBreakerListener impl Line 67  public class CircuitBreakerListener impl
67       */       */
68      public void contextDestroyed(ServletContextEvent sce) {      public void contextDestroyed(ServletContextEvent sce) {
69          logger.warning("Context Destroyed");          logger.warning("Context Destroyed");
70          JMXWrapper.unregisterAllCircuitBreakers();          CircuitBreakerManager.getManager().shutdown();
71    
72            //JMXWrapper.unregisterAllCircuitBreakers();
73      }      }
74                    
75  }  }

Legend:
Removed from v.425  
changed lines
  Added in v.1399

  ViewVC Help
Powered by ViewVC 1.1.20