/[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

CircuitBreaker/src/dk/thoerup/curcuitbreaker/web/ViewCircuitBreaker.java revision 448 by torben, Mon Oct 19 14:04:40 2009 UTC miscJava/CircuitBreaker/src/main/java/dk/thoerup/circuitbreaker/web/ViewCircuitBreaker.java revision 2569 by torben, Tue Jun 9 08:55:10 2015 UTC
# Line 1  Line 1 
1  package dk.thoerup.curcuitbreaker.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.curcuitbreaker.AccountingCircuitBreaker;  import dk.thoerup.circuitbreaker.CircuitBreaker;
11  import dk.thoerup.curcuitbreaker.CircuitBreaker;  import dk.thoerup.circuitbreaker.CircuitBreakerManager;
12  import dk.thoerup.curcuitbreaker.CircuitBreakerManager;  import dk.thoerup.circuitbreaker.statistics.AccountingStatistics;
13    import dk.thoerup.circuitbreaker.statistics.LoggingStatistics;
14    import dk.thoerup.circuitbreaker.statistics.Statistics;
15    
16  public class ViewCircuitBreaker implements Command {  public class ViewCircuitBreaker implements Command {
17                    
# Line 45  public class ViewCircuitBreaker implemen Line 49  public class ViewCircuitBreaker implemen
49                  return sb.toString();                  return sb.toString();
50          }          }
51                    
52            public static String formatDate(long date) {
53                    if (date == 0L) {
54                            return "-";
55                    } else {
56                            return new Date(date).toString();
57                    }
58            }
59            
60          public String execute(HttpServletRequest req, HttpServletResponse resp) {          public String execute(HttpServletRequest req, HttpServletResponse resp) {
61                  CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker( req.getParameter("breaker"));                  CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker( req.getParameter("breaker"));
62                  String uri = req.getRequestURI();                  String uri = req.getRequestURI();
# Line 52  public class ViewCircuitBreaker implemen Line 64  public class ViewCircuitBreaker implemen
64                  if (breaker == null)                                      if (breaker == null)                    
65                          return "<html><body><h2>No breaker named '" + req.getParameter("breaker") + "'</h2></body></html>";                          return "<html><body><h2>No breaker named '" + req.getParameter("breaker") + "'</h2></body></html>";
66                                    
67                    Statistics stats = breaker.getStatistics();
68                    
69                  StringBuilder sb = new StringBuilder();                  StringBuilder sb = new StringBuilder();
70                                    
71                  sb.append("<html><head><title>View Circuitbreaker</title></head><body>");                  sb.append("<html><head><title>View Circuitbreaker</title></head><body>");
72                  sb.append("<<== <a href=\"").append(req.getRequestURI()).append("\">Back to overview</a><br><br>");                  sb.append("<<== <a href=\"").append(req.getRequestURI()).append("\">Back to overview</a><br><br>");
73                  sb.append("<h2>CircuitBreaker</h2>\n");                  sb.append("<h2>CircuitBreaker</h2>\n");
74                                                    
75                                    
76                  sb.append("<b>Attributes:</b>\n");                  sb.append("<b>Attributes:</b>\n");
77                  sb.append("<table border=\"1\" cellspacing=0>");                                  sb.append("<table border=\"1\" cellspacing=0>");                
78                  sb.append("<tr><td>Name </td><td>").append(breaker.getName()).append("</td></tr>\n");                  sb.append("<tr><td>Name </td><td>").append(breaker.getName()).append("</td></tr>\n");
79                  sb.append("<tr><td>State </td><td><b>").append(  breaker ).append("</b></td></tr>\n");                  sb.append("<tr><td>State </td><td><b>").append(  getStateBar(breaker) ).append("</b></td></tr>\n");
80                  sb.append("<tr><td>Type </td><td>").append(breaker.getClass().getSimpleName() ).append("</td></tr>\n");                  sb.append("<tr><td>Type </td><td>").append(breaker.getClass().getSimpleName() ).append("</td></tr>\n");
81                  sb.append("<tr><td>Notifier </td><td>").append(breaker.getNotifierName()).append("</td></tr>\n");                  sb.append("<tr><td>Notifier </td><td>").append(breaker.getNotifierName()).append("</td></tr>\n");
82                    sb.append("<tr><td>Statistics </td><td>").append( stats.getClass().getSimpleName() ).append("</td></tr>\n");
83                  sb.append("<tr><td>Failure count </td><td>").append(breaker.getFailureCount()).append("</td></tr>\n");                  sb.append("<tr><td>Failure count </td><td>").append(breaker.getFailureCount()).append("</td></tr>\n");
84                  sb.append("<tr><td>Failure threshold </td><td>").append(breaker.getThreshold()).append("</td></tr>\n");                  sb.append("<tr><td>Failure threshold </td><td>").append(breaker.getThreshold()).append("</td></tr>\n");
85                  sb.append("<tr><td>Timeout, elapsed</td><td>").append( breaker.getElapsed() ).append("</td></tr>\n");                  sb.append("<tr><td>Timeout, elapsed</td><td>").append( breaker.getElapsed() ).append("</td></tr>\n");
86                  sb.append("<tr><td>Timeout, limit</td><td>").append( breaker.getTimeout() ).append("</td></tr>\n");                  sb.append("<tr><td>Timeout, limit</td><td>").append( breaker.getTimeout() ).append("</td></tr>\n");
87                                    
88                  if (breaker instanceof AccountingCircuitBreaker) {                  
89                          AccountingCircuitBreaker acb = (AccountingCircuitBreaker) breaker;                  
90                    if (stats instanceof AccountingStatistics) {
91                            AccountingStatistics ac = (AccountingStatistics) stats;
92            
93                            StringBuilder sbf = new StringBuilder();
94                            if (ac.getTotalCallCount() > 0) {
95                                    double failure_percentage = ((double) ac.getTotalFailureCount()*100) / ((double) ac.getTotalCallCount() );
96                                    Formatter formatter = new Formatter(sbf);
97                                    formatter.format("%.2f", failure_percentage);
98                                    formatter.close();
99                            } else {
100                                    sbf.append("0.0");
101                            }
102                            
103    
104                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");                          sb.append("<tr><th colspan=\"2\">Accounting</th></tr>\n");
105                          sb.append("<tr><td>Trip count</td><td>").append( acb.getTripCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Trip count</td><td>").append( ac.getTripCount() ).append("</td></tr>\n");
106                          sb.append("<tr><td>Block count</td><td>").append( acb.getBlockCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Re-trip count</td><td>").append( ac.getRetripCount() ).append("</td></tr>\n");
107                          sb.append("<tr><td>Total failure count</td><td>").append( acb.getTotalFailureCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Block count</td><td>").append( ac.getBlockCount() ).append("</td></tr>\n");
108                          sb.append("<tr><td>Total Call count</td><td>").append( acb.getTotalCallCount() ).append("</td></tr>\n");                          sb.append("<tr><td>Total failure count</td><td>").append( ac.getTotalFailureCount() ).append("</td></tr>\n");
109                          sb.append("<tr><td>Last reset</td><td>").append( new Date(acb.getLastResetCounters()).toString() ).append("</td></tr>\n");                                                sb.append("<tr><td>Total Call count</td><td>").append( ac.getTotalCallCount() ).append("</td></tr>\n");
110                            sb.append("<tr><td>Failure Percentage</td><td>").append( sbf.toString() ).append("%</td></tr>\n");
111                            sb.append("<tr><td>Last failure</td><td>").append( formatDate(ac.getLastFailure()) ).append("</td></tr>\n");
112                            sb.append("<tr><td>Last trip</td><td>").append( formatDate(ac.getLastTrip()) ).append("</td></tr>\n");
113                            sb.append("<tr><td>Last re-trip</td><td>").append( formatDate(ac.getLastRetrip()) ).append("</td></tr>\n");
114                            sb.append("<tr><td>Last reset</td><td>").append( formatDate(ac.getLastReset()) ).append("</td></tr>\n");
115                            
116                            sb.append("<tr><td>Last resetCounters</td><td>").append( formatDate(ac.getLastResetCounters()) ).append("</td></tr>\n");                        
117                    }
118    
119                    if (stats instanceof LoggingStatistics) {
120                            LoggingStatistics ls = (LoggingStatistics) stats;                      
121                            
122                            LinkedList<LoggingStatistics.LogEntry> list = ls.getLog();
123                            String headerLink = String.format("<a href=\"%s?command=log&breaker=%s\">Logging</a>", req.getRequestURI(), breaker.getName() );
124    
125                            sb.append("<tr><th colspan=\"2\">").append(headerLink).append("</th></tr>\n");
126                            
127                            int max = list.size() > 10 ? 10 : list.size();                  
128                            for (int i=0; i<max; i++) {
129                                    LoggingStatistics.LogEntry entry = list.get(i);
130                                    sb.append("<tr><td colspan=\"2\">");
131                                    sb.append( entry.toString() );                          
132                                    sb.append("</td></tr>");
133                            }
134                  }                  }
135                                    
136                  sb.append("</table><br>\n");                  sb.append("</table>\n");
137                    sb.append("Current time: ").append( new Date().toString() ).append("<br><br>\n");
138                                    
139                  sb.append("<b>Operations:</b>\n");                  sb.append("<b>Operations:</b>\n");
140                  if ( !readOnly ) {                  if ( !readOnly ) {
141                          sb.append( actionBuilder(uri, "reset", breaker.getName())).append("<br>\n");                                      sb.append( actionBuilder(uri, "reset", breaker.getName())).append("<br>\n");            
142                          sb.append( actionBuilder(uri, "tripBreaker", breaker.getName())).append("<br>\n");                          sb.append( actionBuilder(uri, "tripBreaker", breaker.getName())).append("<br>\n");
143                          if (breaker instanceof AccountingCircuitBreaker ) {                          if (stats instanceof AccountingStatistics ) {
144                                  sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");                                      sb.append( actionBuilder(uri, "resetCounters", breaker.getName())).append("<br>\n");    
145                          }                          }
146                            if (stats instanceof LoggingStatistics ) {
147                                    sb.append( actionBuilder(uri, "clearLog", breaker.getName())).append("<br>\n");
148                            }
149                  } else {                  } else {
150                          sb.append("<i>the CircuitBreakers can only be viewed</i>");                          sb.append("<i>the CircuitBreakers can only be viewed</i>");
151                  }                  }

Legend:
Removed from v.448  
changed lines
  Added in v.2569

  ViewVC Help
Powered by ViewVC 1.1.20