blob: 71704adfb1fac9ea16be6d1c509007ebae4ff32b [file] [log] [blame]
Yuta HIGUCHI6a462832014-11-23 23:56:03 -08001/*
2 * Copyright 2014 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Brian O'Connorabafb502014-12-02 22:26:20 -080017package org.onosproject.cli;
Yuta HIGUCHI6a462832014-11-23 23:56:03 -080018
19import static java.lang.String.format;
20
21import java.util.Comparator;
22import java.util.Map;
23import java.util.Map.Entry;
24
25import org.apache.karaf.shell.commands.Command;
26import org.joda.time.LocalDateTime;
27import org.onlab.metrics.MetricsService;
28
29import com.codahale.metrics.Counter;
30import com.codahale.metrics.Gauge;
31import com.codahale.metrics.Histogram;
32import com.codahale.metrics.Meter;
33import com.codahale.metrics.Metric;
34import com.codahale.metrics.MetricFilter;
35import com.codahale.metrics.Snapshot;
36import com.codahale.metrics.Timer;
37import com.google.common.base.Strings;
38import com.google.common.collect.Ordering;
39import com.google.common.collect.TreeMultimap;
40
41/**
42 * Prints metrics in the system.
43 */
44@Command(scope = "onos", name = "metrics",
45 description = "Prints metrics in the system")
46public class MetricsListCommand extends AbstractShellCommand {
47
48 @Override
49 protected void execute() {
50 MetricsService metricsService = get(MetricsService.class);
51
Yuta HIGUCHI6a462832014-11-23 23:56:03 -080052 MetricFilter filter = MetricFilter.ALL;
53
54 TreeMultimap<String, Metric> matched = listMetrics(metricsService, filter);
55 matched.asMap().forEach((name, metrics) -> {
56 for (Metric metric : metrics) {
Yuta HIGUCHI6a462832014-11-23 23:56:03 -080057 printMetric(name, metric);
58 }
59 });
60 }
61
62 /**
63 * Print metric object.
64 *
65 * @param name metric name
66 * @param metric metric object
67 */
68 private void printMetric(String name, Metric metric) {
69 final String heading;
70
71 if (metric instanceof Counter) {
72 heading = format("-- %s : [%s] --", name, "Counter");
73 print(heading);
74 Counter counter = (Counter) metric;
75 print(" count = %d", counter.getCount());
76
77 } else if (metric instanceof Gauge) {
78 heading = format("-- %s : [%s] --", name, "Gauge");
79 print(heading);
80 @SuppressWarnings("rawtypes")
81 Gauge gauge = (Gauge) metric;
82 final Object value = gauge.getValue();
83 if (name.endsWith("EpochMs") && value instanceof Long) {
84 print(" value = %s (%s)", value, new LocalDateTime(value));
85 } else {
86 print(" value = %s", value);
87 }
88
89 } else if (metric instanceof Histogram) {
90 heading = format("-- %s : [%s] --", name, "Histogram");
91 print(heading);
92 final Histogram histogram = (Histogram) metric;
93 final Snapshot snapshot = histogram.getSnapshot();
94 print(" count = %d", histogram.getCount());
95 print(" min = %d", snapshot.getMin());
96 print(" max = %d", snapshot.getMax());
97 print(" mean = %f", snapshot.getMean());
98 print(" stddev = %f", snapshot.getStdDev());
99
100 } else if (metric instanceof Meter) {
101 heading = format("-- %s : [%s] --", name, "Meter");
102 print(heading);
103 final Meter meter = (Meter) metric;
104 print(" count = %d", meter.getCount());
105 print(" mean rate = %f", meter.getMeanRate());
106 print(" 1-minute rate = %f", meter.getOneMinuteRate());
107 print(" 5-minute rate = %f", meter.getFiveMinuteRate());
108 print(" 15-minute rate = %f", meter.getFifteenMinuteRate());
109
110 } else if (metric instanceof Timer) {
111 heading = format("-- %s : [%s] --", name, "Timer");
112 print(heading);
113 final Timer timer = (Timer) metric;
114 final Snapshot snapshot = timer.getSnapshot();
115 print(" count = %d", timer.getCount());
116 print(" mean rate = %f", timer.getMeanRate());
117 print(" 1-minute rate = %f", timer.getOneMinuteRate());
118 print(" 5-minute rate = %f", timer.getFiveMinuteRate());
119 print(" 15-minute rate = %f", timer.getFifteenMinuteRate());
120 print(" min = %f ms", nanoToMs(snapshot.getMin()));
121 print(" max = %f ms", nanoToMs(snapshot.getMax()));
122 print(" mean = %f ms", nanoToMs(snapshot.getMean()));
123 print(" stddev = %f ms", nanoToMs(snapshot.getStdDev()));
124 } else {
125 heading = format("-- %s : [%s] --", name, metric.getClass().getCanonicalName());
126 print(heading);
127 print("Unknown Metric type:{}", metric.getClass().getCanonicalName());
128 }
129 print(Strings.repeat("-", heading.length()));
130 }
131
132 @SuppressWarnings("rawtypes")
133 private TreeMultimap<String, Metric> listMetrics(MetricsService metricsService, MetricFilter filter) {
134 TreeMultimap<String, Metric> metrics = TreeMultimap.create(Comparator.naturalOrder(), Ordering.arbitrary());
135
136 Map<String, Counter> counters = metricsService.getCounters(filter);
137 for (Entry<String, Counter> entry : counters.entrySet()) {
138 metrics.put(entry.getKey(), entry.getValue());
139 }
140 Map<String, Gauge> gauges = metricsService.getGauges(filter);
141 for (Entry<String, Gauge> entry : gauges.entrySet()) {
142 metrics.put(entry.getKey(), entry.getValue());
143 }
144 Map<String, Histogram> histograms = metricsService.getHistograms(filter);
145 for (Entry<String, Histogram> entry : histograms.entrySet()) {
146 metrics.put(entry.getKey(), entry.getValue());
147 }
148 Map<String, Meter> meters = metricsService.getMeters(filter);
149 for (Entry<String, Meter> entry : meters.entrySet()) {
150 metrics.put(entry.getKey(), entry.getValue());
151 }
152 Map<String, Timer> timers = metricsService.getTimers(filter);
153 for (Entry<String, Timer> entry : timers.entrySet()) {
154 metrics.put(entry.getKey(), entry.getValue());
155 }
156
157 return metrics;
158 }
159
160 private double nanoToMs(double nano) {
161 return nano / 1_000_000D;
162 }
163}