sysmon/plugins/os-base/src/main/java/sysmon/plugins/os_base/BaseMemoryExtension.java

104 lines
2.7 KiB
Java
Raw Normal View History

2021-05-28 13:52:33 +00:00
package sysmon.plugins.os_base;
import org.pf4j.Extension;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import oshi.hardware.HardwareAbstractionLayer;
import sysmon.shared.Measurement;
import sysmon.shared.MetricExtension;
import sysmon.shared.MetricResult;
import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;
2021-05-28 13:52:33 +00:00
@Extension
public class BaseMemoryExtension implements MetricExtension {
private static final Logger log = LoggerFactory.getLogger(BaseMemoryExtension.class);
2021-09-10 10:15:33 +00:00
// Extension details
private final String name = "base_memory";
private final String provides = "memory";
private final String description = "Base Memory Metrics";
// Configuration / Options
private boolean enabled = true;
private boolean threaded = false;
private String interval = "10s";
2021-09-10 10:15:33 +00:00
2021-05-28 13:52:33 +00:00
private HardwareAbstractionLayer hardwareAbstractionLayer;
2021-09-10 10:15:33 +00:00
@Override
public boolean isEnabled() {
return enabled;
}
@Override
public boolean isThreaded() {
return threaded;
}
2021-05-28 13:52:33 +00:00
@Override
public boolean isSupported() {
hardwareAbstractionLayer = BasePlugin.getHardwareAbstractionLayer();
return hardwareAbstractionLayer != null;
2021-05-28 13:52:33 +00:00
}
@Override
public String getName() {
2021-09-10 10:15:33 +00:00
return name;
2021-05-28 13:52:33 +00:00
}
@Override
public String getInterval() {
return interval;
}
2021-05-28 13:52:33 +00:00
@Override
public String getProvides() {
2021-09-10 10:15:33 +00:00
return provides;
2021-05-28 13:52:33 +00:00
}
@Override
public String getDescription() {
2021-09-10 10:15:33 +00:00
return description;
}
@Override
public void setConfiguration(Map<String, Object> map) {
if (map.containsKey("enabled")) {
enabled = (boolean) map.get("enabled");
}
if(map.containsKey("threaded")) {
threaded = (boolean) map.get("threaded");
}
if(map.containsKey("interval")) {
interval = (String) map.get("interval");
}
2021-05-28 13:52:33 +00:00
}
@Override
public MetricResult getMetrics() {
TreeMap<String, String> tagsMap = new TreeMap<>();
TreeMap<String, Object> fieldsMap = new TreeMap<>();
2021-05-28 13:52:33 +00:00
long total = hardwareAbstractionLayer.getMemory().getTotal();
long available = hardwareAbstractionLayer.getMemory().getAvailable();
float usage = ((float) (total - available) / total ) * 100;
fieldsMap.put("available", available);
fieldsMap.put("total", total);
fieldsMap.put("usage", usage);
fieldsMap.put("paged", hardwareAbstractionLayer.getMemory().getPageSize());
fieldsMap.put("virtual", hardwareAbstractionLayer.getMemory().getVirtualMemory().getVirtualInUse());
2021-05-31 12:44:48 +00:00
log.debug(fieldsMap.toString());
2021-09-10 10:15:33 +00:00
return new MetricResult(name, new Measurement(tagsMap, fieldsMap));
2021-05-28 13:52:33 +00:00
}
}