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

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

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

revision 624 by torben, Mon Mar 8 09:46:10 2010 UTC revision 1844 by torben, Fri Aug 31 06:33:12 2012 UTC
# Line 1  Line 1 
1  package dk.thoerup.circuitbreaker.web;  package dk.thoerup.circuitbreaker.web;
2    
3  import java.util.Date;  import java.util.Date;
4    import java.util.Formatter;
5    import java.util.LinkedList;
6    
7  import javax.servlet.http.HttpServletRequest;  import javax.servlet.http.HttpServletRequest;
8  import javax.servlet.http.HttpServletResponse;  import javax.servlet.http.HttpServletResponse;
9    
10  import dk.thoerup.circuitbreaker.AccountingCircuitBreaker;  import dk.thoerup.circuitbreaker.AccountingCircuitBreaker;
11    import dk.thoerup.circuitbreaker.LoggingCircuitBreaker;
12  import dk.thoerup.circuitbreaker.CircuitBreaker;  import dk.thoerup.circuitbreaker.CircuitBreaker;
13  import dk.thoerup.circuitbreaker.CircuitBreakerManager;  import dk.thoerup.circuitbreaker.CircuitBreakerManager;
14    
# Line 45  public class ViewCircuitBreaker implemen Line 48  public class ViewCircuitBreaker implemen
48                  return sb.toString();                  return sb.toString();
49          }          }
50                    
51            public static String formatDate(long date) {
52                    if (date == 0L) {
53                            return "-";
54                    } else {
55                            return new Date(date).toString();
56                    }
57            }
58            
59          public String execute(HttpServletRequest req, HttpServletResponse resp) {          public String execute(HttpServletRequest req, HttpServletResponse resp) {
60                  CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker( req.getParameter("breaker"));                  CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker( req.getParameter("breaker"));
61                  String uri = req.getRequestURI();                  String uri = req.getRequestURI();
# Line 72  public class ViewCircuitBreaker implemen Line 83  public class ViewCircuitBreaker implemen
83                                    
84                  if (breaker instanceof AccountingCircuitBreaker) {                  if (breaker instanceof AccountingCircuitBreaker) {
85                          AccountingCircuitBreaker acb = (AccountingCircuitBreaker) breaker;                          AccountingCircuitBreaker acb = (AccountingCircuitBreaker) breaker;
86            
87                            double failure_percentage = ((double) acb.getTotalFailureCount()*100) / ((double) acb.getTotalCallCount() );
88                            StringBuilder sbf = new StringBuilder();
89                            Formatter formatter = new Formatter(sb);
90                            formatter.format("%.2f", failure_percentage);
91                            
92    
93                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");
94                          sb.append("<tr><td>Trip count</td><td>").append( acb.getTripCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Trip count</td><td>").append( acb.getTripCount() ).append("</td></tr>\n");
95                            sb.append("<tr><td>Re-trip count</td><td>").append( acb.getRetripCount() ).append("</td></tr>\n");
96                          sb.append("<tr><td>Block count</td><td>").append( acb.getBlockCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Block count</td><td>").append( acb.getBlockCount() ).append("</td></tr>\n");
97                          sb.append("<tr><td>Total failure count</td><td>").append( acb.getTotalFailureCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Total failure count</td><td>").append( acb.getTotalFailureCount() ).append("</td></tr>\n");
98                          sb.append("<tr><td>Total Call count</td><td>").append( acb.getTotalCallCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Total Call count</td><td>").append( acb.getTotalCallCount() ).append("</td></tr>\n");
99                          sb.append("<tr><td>Last failure</td><td>").append( new Date(acb.getLastFailure()).toString() ).append("</td></tr>\n");                          sb.append("<tr><td>Failure Percentage</td><td>").append( sb.toString() ).append("%</td></tr>\n");
100                          sb.append("<tr><td>Last trip</td><td>").append( new Date(acb.getLastTrip()).toString() ).append("</td></tr>\n");                          sb.append("<tr><td>Last failure</td><td>").append( formatDate(acb.getLastFailure()) ).append("</td></tr>\n");
101                          sb.append("<tr><td>Last reset</td><td>").append( new Date(acb.getLastReset()).toString() ).append("</td></tr>\n");                          sb.append("<tr><td>Last trip</td><td>").append( formatDate(acb.getLastTrip()) ).append("</td></tr>\n");
102                            sb.append("<tr><td>Last re-trip</td><td>").append( formatDate(acb.getLastRetrip()) ).append("</td></tr>\n");
103                            sb.append("<tr><td>Last reset</td><td>").append( formatDate(acb.getLastReset()) ).append("</td></tr>\n");
104                                                    
105                          sb.append("<tr><td>Last resetCounters</td><td>").append( new Date(acb.getLastResetCounters()).toString() ).append("</td></tr>\n");                                                sb.append("<tr><td>Last resetCounters</td><td>").append( formatDate(acb.getLastResetCounters()) ).append("</td></tr>\n");                      
106                    }
107    
108                    if (breaker instanceof LoggingCircuitBreaker) {
109                            LoggingCircuitBreaker lcb = (LoggingCircuitBreaker) breaker;                    
110                            
111                            LinkedList<LoggingCircuitBreaker.LogEntry> list = lcb.getLog();
112                            String headerLink = String.format("<a href=\"%s?command=log&breaker=%s\">Logging</a>", req.getRequestURI(), breaker.getName() );
113    
114                            sb.append("<tr><th colspan=\"2\">").append(headerLink).append("</th></tr>\n");
115                            
116                            int max = list.size() > 10 ? 10 : list.size();                  
117                            for (int i=0; i<max; i++) {
118                                    LoggingCircuitBreaker.LogEntry entry = list.get(i);
119                                    sb.append("<tr><td colspan=\"2\">");
120                                    sb.append( entry.toString() );                          
121                                    sb.append("</td></tr>");
122                            }
123                  }                  }
124                                    
125                  sb.append("</table><br>\n");                  sb.append("</table>\n");
126                    sb.append("Current time: ").append( new Date().toString() ).append("<br><br>\n");
127                                    
128                  sb.append("<b>Operations:</b>\n");                  sb.append("<b>Operations:</b>\n");
129                  if ( !readOnly ) {                  if ( !readOnly ) {
# Line 93  public class ViewCircuitBreaker implemen Line 132  public class ViewCircuitBreaker implemen
132                          if (breaker instanceof AccountingCircuitBreaker ) {                          if (breaker instanceof AccountingCircuitBreaker ) {
133                                  sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");                                      sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");    
134                          }                          }
135                            if (breaker instanceof LoggingCircuitBreaker ) {
136                                    sb.append( actionBuilder(uri, "clearLog", breaker.getName())).append("<br>\n");
137                            }
138                  } else {                  } else {
139                          sb.append("<i>the CircuitBreakers can only be viewed</i>");                          sb.append("<i>the CircuitBreakers can only be viewed</i>");
140                  }                  }

Legend:
Removed from v.624  
changed lines
  Added in v.1844

  ViewVC Help
Powered by ViewVC 1.1.20