/
MetricsRegistry.java
71 lines (60 loc) · 2.67 KB
/
MetricsRegistry.java
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package org.bimserver;
/******************************************************************************
* Copyright (C) 2009-2017 BIMserver.org
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see {@literal<http://www.gnu.org/licenses/>}.
*****************************************************************************/
import java.util.HashMap;
import java.util.Map;
import org.bimserver.interfaces.objects.SInterfaceMetric;
import org.bimserver.interfaces.objects.SMethodMetric;
import org.bimserver.interfaces.objects.SMetrics;
import org.bimserver.shared.meta.SMethod;
import org.bimserver.shared.meta.SService;
public class MetricsRegistry {
private final Map<SService, Map<SMethod, MethodStats>> methodStats = new HashMap<>();
public Recording startRecording(SService sService, SMethod method) {
return new Recording(this, sService, method);
}
public synchronized MethodStats getMethodStats(SMethod sMethod) {
Map<SMethod, MethodStats> map = this.methodStats.get(sMethod.getService());
if (map == null) {
map = new HashMap<SMethod, MethodStats>();
this.methodStats.put(sMethod.getService(), map);
}
MethodStats methodStats = map.get(sMethod);
if (methodStats == null) {
methodStats = new MethodStats(sMethod.getService(), sMethod);
map.put(sMethod, methodStats);
}
return methodStats;
}
public synchronized SMetrics getMetrics() {
SMetrics sMetrics = new SMetrics();
for (SService sService : methodStats.keySet()) {
SInterfaceMetric interfaceMetric = new SInterfaceMetric();
interfaceMetric.setName(sService.getSimpleName());
sMetrics.getInterfaces().add(interfaceMetric);
for (SMethod sMethod : methodStats.get(sService).keySet()) {
SMethodMetric sMethodMetric = new SMethodMetric();
sMethodMetric.setName(sMethod.getName());
interfaceMetric.getMethods().add(sMethodMetric);
MethodStats methodStats = getMethodStats(sMethod);
sMethodMetric.setNrCalls(methodStats.getNrCalls());
sMethodMetric.setAverageMs(methodStats.getAverageNanoSecondsPerCall() / 1000000);
}
}
return sMetrics;
}
}