aboutsummaryrefslogtreecommitdiffstats
path: root/messagebus/src/main/java/com/yahoo/messagebus/metrics/MessageBusMetricSet.java
blob: ad1d97a25ad1ab3ccfff5e60f5708a38741712d5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// Copyright 2017 Yahoo Holdings. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.messagebus.metrics;

import com.yahoo.concurrent.CopyOnWriteHashMap;
import com.yahoo.messagebus.Reply;
import com.yahoo.messagebus.routing.Route;

/**
 * @author thomasg
 */
public class MessageBusMetricSet extends MetricSet {
    public MetricSet protocols = new MetricSet("protocols");

    private final CopyOnWriteHashMap<String, RouteMetricSet> routeMetrics = new CopyOnWriteHashMap<String, RouteMetricSet>();

    public MessageBusMetricSet() {
        super("messagebus");
        addMetric(protocols);
    }

    public RouteMetricSet getRouteMetrics(Route r) {
        String route = r.toString();
        RouteMetricSet metric = routeMetrics.get(route);
        if (metric == null) {
            synchronized (routeMetrics) {
                metric = routeMetrics.get(route);
                if (metric == null) {
                    metric = new RouteMetricSet(route);
                    addMetric(metric);
                    routeMetrics.put(route, metric);
                }
            }
        }

        return metric;
    }

    public void updateMetrics(Reply reply, Route r) {

    }

}