/[projects]/miscJava/CircuitBreaker/src/main/java/dk/thoerup/circuitbreaker/CircuitBreaker.java
ViewVC logotype

Diff of /miscJava/CircuitBreaker/src/main/java/dk/thoerup/circuitbreaker/CircuitBreaker.java

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

CircuitBreaker/src/dk/thoerup/curcuitbreaker/CircuitBreaker.java revision 395 by torben, Mon Oct 5 19:54:25 2009 UTC CircuitBreaker/src/dk/thoerup/circuitbreaker/CircuitBreaker.java revision 627 by torben, Mon Mar 8 10:12:59 2010 UTC
# Line 1  Line 1 
1  package dk.thoerup.curcuitbreaker;  package dk.thoerup.circuitbreaker;
2    
3  import java.util.logging.Logger;  
4    import dk.thoerup.circuitbreaker.notification.Notifier;
5    import dk.thoerup.circuitbreaker.notification.NullNotifier;
6    
7  /* Simple CircuitBreaker implementation - snipped from http://www.jroller.com/kenwdelong/entry/circuit_breaker_in_java  /* Simple CircuitBreaker implementation - snipped from http://www.jroller.com/kenwdelong/entry/circuit_breaker_in_java
8   *   *
# Line 29  import java.util.logging.Logger; Line 31  import java.util.logging.Logger;
31                  try {                  try {
32                          String s = (String) cb.invoke(new TestInvocation("http://rafiki/test"));                          String s = (String) cb.invoke(new TestInvocation("http://rafiki/test"));
33                          response.getWriter().print(s);                          response.getWriter().print(s);
34                  } catch (Throwable e) {                  } catch (Exception e) {
35                          logger.warning( e.getMessage() );                          logger.warning( e.getMessage() );
36                          response.sendError(500);                          response.sendError(500);
37                          return;                          return;
# Line 40  import java.util.logging.Logger; Line 42  import java.util.logging.Logger;
42    
43    
44  public class CircuitBreaker{  public class CircuitBreaker{
         Logger logger = Logger.getLogger(CircuitBreaker.class.getName());  
   
45                    
46          private CircuitBreakerState currentState;          private volatile CircuitBreakerState currentState;
47                    
48          private OpenState open = new OpenState();          private final OpenState open = new OpenState();
49          private HalfOpenState halfOpen = new HalfOpenState();          private final HalfOpenState halfOpen = new HalfOpenState();
50          private ClosedState closed = new ClosedState();          private final ClosedState closed = new ClosedState();
51                    
52          private String name;          private String name;
53                    
54            private Notifier notifier = new NullNotifier();
55            
56          public CircuitBreaker(String name, int threshold, long timeoutMS) {          public CircuitBreaker(String name, int threshold, long timeoutMS) {
57                  closed.setThreshold(threshold);                  closed.setThreshold(threshold);
58                  open.setTimeout(timeoutMS);                  open.setTimeout(timeoutMS);
59                                    
60                  this.name = name;                  this.name = name;
61                            
62                  reset();                  //set correct intial state
63                    internalReset();
64          }          }
65                    
66                    
67      public Object invoke(CircuitInvocation invocation) throws Throwable      public Object invoke(CircuitInvocation invocation) throws Exception
68      {      {
69          Object result = null;          Object result = null;
70          try          try
# Line 70  public class CircuitBreaker{ Line 73  public class CircuitBreaker{
73              result = invocation.proceed();              result = invocation.proceed();
74              getState().postInvoke(this);              getState().postInvoke(this);
75          }          }
76          catch(Throwable t)          catch(Exception e)
77          {          {
78              getState().onError(this, t);              getState().onError(this, e);
79              throw t;              throw e;
80          }          }
81          return result;          return result;
82      }      }
83            
84      public void tripBreaker() {      public void tripBreaker() {
85          synchronized(this) {          synchronized(this) {
86                  currentState = open;                  if (currentState != open) { // TODO:Is this conditional necessary ??
87                  open.trip();                          open.trip();
88                            currentState = open;
89                                    
90                  logger.warning("Circuitbreaker tripBreaker - " + name);                          notifier.sendNotification(name, Notifier.Event.BreakerTripped);
91          }                  }
92                }    
93      }      }
94            
95      public void attemptReset() {      public void attemptReset() {
96          synchronized(this) {          synchronized(this) {
97                  currentState = halfOpen;                  if (currentState != halfOpen) { // TODO:Is this conditional necessary ??
98                                            currentState = halfOpen;
99                  logger.warning("Circuitbreaker attemptReset - " + name);                          notifier.sendNotification(name, Notifier.Event.BreakerAttemptReset);
100                    }
101          }          }
102            
103      }      }
104            
105      public void reset() {      public void reset() {
106          synchronized(this) {          synchronized(this) {
107                  currentState = closed;                  if (currentState != closed) { // TODO: Is this conditional necessary ??
108                                            internalReset();
109                  logger.warning("Circuitbreaker reset - " + name);                          notifier.sendNotification(name, Notifier.Event.BreakerReset);
110                    }
111          }          }
112      }      }
113            
114        //This one actually sets the correct closed/reset state
115        private void internalReset() {
116                    closed.resetFailureCount();
117                    currentState = closed;          
118        }
119        
120        
121      private CircuitBreakerState getState() {      private CircuitBreakerState getState() {
122          synchronized(this) {          synchronized(this) {
123                  return currentState;                  return currentState;
124          }          }
125      }      }
126        
127        public boolean isClosed() {
128            return (getState() == closed);
129        }
130        
131        public boolean isOpen() {
132            return (getState() == open);
133        }
134        
135        public String getName() {
136            return name;
137        }
138        
139        public String getStateName() {
140            return getState().getName();
141        }
142        
143        public int getThreshold() {
144            return closed.getThreshold();
145        }
146        
147        public int getTimeout() {
148            return (int)open.getTimeout();
149        }
150        
151        public int getFailureCount() {
152            if (getState() == closed) {
153                    return closed.getFailureCount();
154            } else {
155                    return -1;
156            }
157        }
158        
159        public long getElapsed() {
160            if (getState() == open) {
161                    return open.getElapsed();
162            } else {
163                    return -1;
164            }
165        }
166        
167        public void setNotifier(Notifier notifier) {
168            this.notifier = notifier;
169        }
170        
171        public String getNotifierName() {
172            return notifier.getClass().getName();
173        }
174    
175  }  }

Legend:
Removed from v.395  
changed lines
  Added in v.627

  ViewVC Help
Powered by ViewVC 1.1.20