commit
3eb2d02040
13
README.md
13
README.md
|
@ -41,12 +41,21 @@ There are few steps in the installation.
|
||||||
- Enable *Performance Monitoring Data Collection for Managed Servers*: **All On**
|
- Enable *Performance Monitoring Data Collection for Managed Servers*: **All On**
|
||||||
- Set *Performance Data Storage* to **1** day or preferable more
|
- Set *Performance Data Storage* to **1** day or preferable more
|
||||||
|
|
||||||
|
If you do not enable *Performance Monitoring Data Collection for Managed Servers*, you will see errors such as *Unexpected response: 403*. Use the *hmci* debug flag to get more details about what is going on.
|
||||||
|
|
||||||
### 2 - InfluxDB and Grafana Installation
|
### 2 - InfluxDB and Grafana Installation
|
||||||
|
|
||||||
Install InfluxDB on an LPAR or VM, which is network accessible by the *HMCi* utility (the default InfluxDB port is 8086). You can install Grafana on the same server or any server which are able to connect to the InfluxDB database. The Grafana installation needs to be accessible from your browser. The default settings for both InfluxDB and Grafana will work fine as a start.
|
Install InfluxDB (v. **1.8** for best compatibility with Grafana) on an LPAR or VM, which is network accessible by the *HMCi* utility (the default InfluxDB port is 8086). You can install Grafana on the same server or any server which are able to connect to the InfluxDB database. The Grafana installation needs to be accessible from your browser. The default settings for both InfluxDB and Grafana will work fine as a start.
|
||||||
|
|
||||||
- You can download [Grafana ppc64le](https://www.power-devops.com/grafana) and [InfluxDB ppc64le](https://www.power-devops.com/influxdb) packages for most Linux distributions and AIX on the [Power DevOps](https://www.power-devops.com/) site.
|
- You can download [Grafana ppc64le](https://www.power-devops.com/grafana) and [InfluxDB ppc64le](https://www.power-devops.com/influxdb) packages for most Linux distributions and AIX on the [Power DevOps](https://www.power-devops.com/) site.
|
||||||
- Binaries for amd64/x86 are available from the [Grafana website](https://grafana.com/grafana/download) and [InfluxDB website](https://portal.influxdata.com/downloads/) and most likely directly from your Linux distributions repositories.
|
- Binaries for amd64/x86 are available from the [Grafana website](https://grafana.com/grafana/download) and [InfluxDB website](https://portal.influxdata.com/downloads/) and most likely directly from your Linux distributions repositories.
|
||||||
|
- Create the empty *hmci* database through the **influx** cli command:
|
||||||
|
|
||||||
|
```text
|
||||||
|
CREATE DATABASE "hmci" WITH DURATION 365d REPLICATION 1;
|
||||||
|
```
|
||||||
|
|
||||||
|
See the [Influx documentation](https://docs.influxdata.com/influxdb/v1.8/query_language/manage-database/#create-database) for more information on duration and replication.
|
||||||
|
|
||||||
### 3 - HMCi Installation & Configuration
|
### 3 - HMCi Installation & Configuration
|
||||||
|
|
||||||
|
@ -59,7 +68,7 @@ Install *HMCi* on a host, which can connect to the Power HMC through HTTPS, and
|
||||||
- On DEB based systems: **sudo dpkg -i hmci_x.y.z-n_all.deb**
|
- On DEB based systems: **sudo dpkg -i hmci_x.y.z-n_all.deb**
|
||||||
- Copy the **/opt/hmci/doc/hmci.toml** configuration example into **/etc/hmci.toml** and edit the configuration to suit your environment. The location of the configuration file can be changed with the *--conf* option.
|
- Copy the **/opt/hmci/doc/hmci.toml** configuration example into **/etc/hmci.toml** and edit the configuration to suit your environment. The location of the configuration file can be changed with the *--conf* option.
|
||||||
- Run the **/opt/hmci/bin/hmci** program in a shell, as a @reboot cron task or configure as a proper service - there are instructions in the *doc/readme-service.md* file.
|
- Run the **/opt/hmci/bin/hmci** program in a shell, as a @reboot cron task or configure as a proper service - there are instructions in the *doc/readme-service.md* file.
|
||||||
- When started, *hmci* will try to create the InfluxDB database named hmci, if not found.
|
- When started, *hmci* expects the InfluxDB database to be created by you.
|
||||||
|
|
||||||
### 4 - Grafana Configuration
|
### 4 - Grafana Configuration
|
||||||
|
|
||||||
|
|
32
build.gradle
32
build.gradle
|
@ -6,9 +6,9 @@ plugins {
|
||||||
// Code coverage of tests
|
// Code coverage of tests
|
||||||
id 'jacoco'
|
id 'jacoco'
|
||||||
|
|
||||||
id "com.github.johnrengelman.shadow" version "7.0.0"
|
id "com.github.johnrengelman.shadow" version "7.1.2"
|
||||||
id "net.nemerosa.versioning" version "2.14.0"
|
id "net.nemerosa.versioning" version "2.15.1"
|
||||||
id "nebula.ospackage" version "8.5.6"
|
id "nebula.ospackage" version "9.1.1"
|
||||||
}
|
}
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
|
@ -16,21 +16,26 @@ repositories {
|
||||||
mavenLocal()
|
mavenLocal()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
group = projectGroup
|
||||||
|
version = projectVersion
|
||||||
|
sourceCompatibility = projectJavaVersion
|
||||||
|
targetCompatibility = projectJavaVersion
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
annotationProcessor 'info.picocli:picocli-codegen:4.6.1'
|
annotationProcessor 'info.picocli:picocli-codegen:4.6.2'
|
||||||
implementation 'info.picocli:picocli:4.6.1'
|
implementation 'info.picocli:picocli:4.6.1'
|
||||||
implementation 'org.jsoup:jsoup:1.14.3'
|
implementation 'org.jsoup:jsoup:1.14.3'
|
||||||
implementation 'com.squareup.okhttp3:okhttp:4.9.2'
|
implementation 'com.squareup.okhttp3:okhttp:4.9.3'
|
||||||
implementation 'com.squareup.moshi:moshi:1.12.0'
|
implementation 'com.squareup.moshi:moshi:1.13.0'
|
||||||
implementation 'com.serjltt.moshi:moshi-lazy-adapters:2.2'
|
implementation 'com.serjltt.moshi:moshi-lazy-adapters:2.2'
|
||||||
implementation 'org.tomlj:tomlj:1.0.0'
|
implementation 'org.tomlj:tomlj:1.0.0'
|
||||||
implementation 'org.influxdb:influxdb-java:2.21'
|
implementation 'org.influxdb:influxdb-java:2.22'
|
||||||
implementation 'org.slf4j:slf4j-api:1.7.32'
|
implementation 'org.slf4j:slf4j-api:1.7.35'
|
||||||
implementation 'org.slf4j:slf4j-simple:1.7.32'
|
implementation 'org.slf4j:slf4j-simple:1.7.35'
|
||||||
|
|
||||||
testImplementation 'org.spockframework:spock-core:2.0-groovy-3.0'
|
testImplementation 'org.spockframework:spock-core:2.0-groovy-3.0'
|
||||||
testImplementation 'com.squareup.okhttp3:mockwebserver:4.9.2'
|
testImplementation 'com.squareup.okhttp3:mockwebserver:4.9.3'
|
||||||
testImplementation 'org.slf4j:slf4j-simple:1.7.32'
|
testImplementation 'org.slf4j:slf4j-simple:1.7.35'
|
||||||
}
|
}
|
||||||
|
|
||||||
application {
|
application {
|
||||||
|
@ -120,12 +125,7 @@ jar {
|
||||||
|
|
||||||
tasks.create("packages") {
|
tasks.create("packages") {
|
||||||
group "build"
|
group "build"
|
||||||
|
|
||||||
dependsOn ":build"
|
dependsOn ":build"
|
||||||
dependsOn ":buildDeb"
|
dependsOn ":buildDeb"
|
||||||
dependsOn ":buildRpm"
|
dependsOn ":buildRpm"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sourceCompatibility = 1.8
|
|
||||||
targetCompatibility = 1.8
|
|
||||||
|
|
|
@ -14,20 +14,18 @@ username = "root"
|
||||||
password = ""
|
password = ""
|
||||||
database = "hmci"
|
database = "hmci"
|
||||||
|
|
||||||
# One or more HMC's to query for data and metrics
|
# HMC to query for data and metrics
|
||||||
[hmc]
|
|
||||||
|
|
||||||
# HMC on our primary site
|
|
||||||
[hmc.site1]
|
[hmc.site1]
|
||||||
url = "https://10.10.10.10:12443"
|
url = "https://10.10.10.10:12443"
|
||||||
username = "hmci"
|
username = "hmci"
|
||||||
password = "hmcihmci"
|
password = "hmcihmci"
|
||||||
unsafe = true # Ignore SSL cert. errors
|
unsafe = true # Ignore SSL cert. errors
|
||||||
|
|
||||||
|
# Another HMC example
|
||||||
# Example
|
|
||||||
#[hmc.site2]
|
#[hmc.site2]
|
||||||
#url = "https://10.10.20.20:12443"
|
#url = "https://10.10.20.20:12443"
|
||||||
#username = "viewer"
|
#username = "viewer"
|
||||||
#password = "someSecret"
|
#password = "someSecret"
|
||||||
#unsafe = false
|
#unsafe = false # When false, validate SSL/TLS cerfificate, default is true
|
||||||
|
#energy = false # When false, do not collect energy metrics, default is true
|
||||||
|
#trace = "/tmp/hmci-trace" # When present, store JSON metrics files from HMC into this folder
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
id = hmci
|
projectId = hmci
|
||||||
group = biz.nellemann.hmci
|
projectGroup = biz.nellemann.hmci
|
||||||
version = 1.2.5
|
projectVersion = 1.2.6
|
||||||
|
projectJavaVersion = 1.8
|
||||||
|
|
|
@ -1,10 +1 @@
|
||||||
/*
|
|
||||||
* This file was generated by the Gradle 'init' task.
|
|
||||||
*
|
|
||||||
* The settings file is used to specify which projects to include in your build.
|
|
||||||
*
|
|
||||||
* Detailed information about configuring a multi-project build in Gradle can be found
|
|
||||||
* in the user manual at https://docs.gradle.org/6.5.1/userguide/multi_project_builds.html
|
|
||||||
*/
|
|
||||||
|
|
||||||
rootProject.name = 'hmci'
|
rootProject.name = 'hmci'
|
||||||
|
|
|
@ -91,6 +91,12 @@ public final class Configuration {
|
||||||
c.unsafe = false;
|
c.unsafe = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(hmcTable.contains(key+".energy")) {
|
||||||
|
c.energy = hmcTable.getBoolean(key+".energy");
|
||||||
|
} else {
|
||||||
|
c.energy = true;
|
||||||
|
}
|
||||||
|
|
||||||
if(hmcTable.contains(key+".trace")) {
|
if(hmcTable.contains(key+".trace")) {
|
||||||
c.trace = hmcTable.getString(key+".trace");
|
c.trace = hmcTable.getString(key+".trace");
|
||||||
} else {
|
} else {
|
||||||
|
@ -185,6 +191,7 @@ public final class Configuration {
|
||||||
String username;
|
String username;
|
||||||
String password;
|
String password;
|
||||||
Boolean unsafe = false;
|
Boolean unsafe = false;
|
||||||
|
Boolean energy = true;
|
||||||
String trace;
|
String trace;
|
||||||
Long update = 30L;
|
Long update = 30L;
|
||||||
Long rescan = 60L;
|
Long rescan = 60L;
|
||||||
|
|
|
@ -47,19 +47,22 @@ class HmcInstance implements Runnable {
|
||||||
|
|
||||||
private File traceDir;
|
private File traceDir;
|
||||||
private Boolean doTrace = false;
|
private Boolean doTrace = false;
|
||||||
|
private Boolean doEnergy = true;
|
||||||
|
|
||||||
HmcInstance(HmcObject configHmc, InfluxClient influxClient) {
|
HmcInstance(HmcObject configHmc, InfluxClient influxClient) {
|
||||||
this.hmcId = configHmc.name;
|
this.hmcId = configHmc.name;
|
||||||
this.updateValue = configHmc.update;
|
this.updateValue = configHmc.update;
|
||||||
this.rescanValue = configHmc.rescan;
|
this.rescanValue = configHmc.rescan;
|
||||||
|
this.doEnergy = configHmc.energy;
|
||||||
this.influxClient = influxClient;
|
this.influxClient = influxClient;
|
||||||
hmcRestClient = new HmcRestClient(configHmc.url, configHmc.username, configHmc.password, configHmc.unsafe);
|
hmcRestClient = new HmcRestClient(configHmc.url, configHmc.username, configHmc.password, configHmc.unsafe);
|
||||||
log.debug(String.format("HmcInstance() - id: %s, update: %s, refresh %s", hmcId, updateValue, rescanValue));
|
log.debug("HmcInstance() - id: {}, update: {}, refresh {}", hmcId, updateValue, rescanValue);
|
||||||
|
|
||||||
if(configHmc.trace != null) {
|
if(configHmc.trace != null) {
|
||||||
try {
|
try {
|
||||||
traceDir = new File(configHmc.trace);
|
traceDir = new File(configHmc.trace);
|
||||||
if(traceDir.mkdirs() && traceDir.canWrite()) {
|
traceDir.mkdirs();
|
||||||
|
if(traceDir.canWrite()) {
|
||||||
doTrace = true;
|
doTrace = true;
|
||||||
} else {
|
} else {
|
||||||
log.warn("HmcInstance() - can't write to trace dir: " + traceDir.toString());
|
log.warn("HmcInstance() - can't write to trace dir: " + traceDir.toString());
|
||||||
|
@ -80,7 +83,7 @@ class HmcInstance implements Runnable {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
|
|
||||||
log.debug("run() - " + hmcId);
|
log.trace("run() - " + hmcId);
|
||||||
int executions = 0;
|
int executions = 0;
|
||||||
|
|
||||||
discover();
|
discover();
|
||||||
|
@ -88,7 +91,9 @@ class HmcInstance implements Runnable {
|
||||||
do {
|
do {
|
||||||
Instant instantStart = Instant.now();
|
Instant instantStart = Instant.now();
|
||||||
try {
|
try {
|
||||||
|
if (doEnergy) {
|
||||||
getMetricsForEnergy();
|
getMetricsForEnergy();
|
||||||
|
}
|
||||||
getMetricsForSystems();
|
getMetricsForSystems();
|
||||||
getMetricsForPartitions();
|
getMetricsForPartitions();
|
||||||
|
|
||||||
|
@ -102,18 +107,18 @@ class HmcInstance implements Runnable {
|
||||||
executions = 0;
|
executions = 0;
|
||||||
discover();
|
discover();
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("run()", e);
|
log.error("run() - fatal error: {}", e.getMessage());
|
||||||
|
throw new RuntimeException(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
Instant instantEnd = Instant.now();
|
Instant instantEnd = Instant.now();
|
||||||
long timeSpend = Duration.between(instantStart, instantEnd).toMillis();
|
long timeSpend = Duration.between(instantStart, instantEnd).toMillis();
|
||||||
log.debug("run() - duration millis: " + timeSpend);
|
log.trace("run() - duration millis: " + timeSpend);
|
||||||
if(timeSpend < (updateValue * 1000)) {
|
if(timeSpend < (updateValue * 1000)) {
|
||||||
try {
|
try {
|
||||||
long sleepTime = (updateValue * 1000) - timeSpend;
|
long sleepTime = (updateValue * 1000) - timeSpend;
|
||||||
log.debug("run() - sleeping millis: " + sleepTime);
|
log.trace("run() - sleeping millis: " + sleepTime);
|
||||||
if(sleepTime > 0) {
|
if(sleepTime > 0) {
|
||||||
//noinspection BusyWait
|
//noinspection BusyWait
|
||||||
sleep(sleepTime);
|
sleep(sleepTime);
|
||||||
|
@ -122,7 +127,7 @@ class HmcInstance implements Runnable {
|
||||||
log.error("run() - sleep interrupted", e);
|
log.error("run() - sleep interrupted", e);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
log.warn("run() - slow response from HMC");
|
log.warn("run() - possible slow response from this HMC");
|
||||||
}
|
}
|
||||||
|
|
||||||
} while (keepRunning.get());
|
} while (keepRunning.get());
|
||||||
|
@ -131,7 +136,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
hmcRestClient.logoff();
|
hmcRestClient.logoff();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log.warn("run() - error logging out: " + e.getMessage());
|
log.warn("run() - error logging out of HMC: " + e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -139,7 +144,7 @@ class HmcInstance implements Runnable {
|
||||||
|
|
||||||
void discover() {
|
void discover() {
|
||||||
|
|
||||||
log.debug("discover()");
|
log.trace("discover()");
|
||||||
|
|
||||||
Map<String, LogicalPartition> tmpPartitions = new HashMap<>();
|
Map<String, LogicalPartition> tmpPartitions = new HashMap<>();
|
||||||
|
|
||||||
|
@ -151,8 +156,10 @@ class HmcInstance implements Runnable {
|
||||||
if(!systems.containsKey(systemId)) {
|
if(!systems.containsKey(systemId)) {
|
||||||
systems.put(systemId, system);
|
systems.put(systemId, system);
|
||||||
log.info("discover() - Found ManagedSystem: " + system);
|
log.info("discover() - Found ManagedSystem: " + system);
|
||||||
|
if(doEnergy) {
|
||||||
hmcRestClient.enableEnergyMonitoring(system);
|
hmcRestClient.enableEnergyMonitoring(system);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Get partitions for this system
|
// Get partitions for this system
|
||||||
try {
|
try {
|
||||||
|
@ -162,13 +169,13 @@ class HmcInstance implements Runnable {
|
||||||
partitions.putAll(tmpPartitions);
|
partitions.putAll(tmpPartitions);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("discover() - getLogicalPartitions", e);
|
log.warn("discover() - getLogicalPartitions error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("discover() - getManagedSystems: " + e.getMessage());
|
log.warn("discover() - getManagedSystems error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -184,7 +191,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
tmpJsonString = hmcRestClient.getPcmDataForManagedSystem(system);
|
tmpJsonString = hmcRestClient.getPcmDataForManagedSystem(system);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("getMetricsForSystems() " + e.getMessage());
|
log.warn("getMetricsForSystems() - error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
if(tmpJsonString != null && !tmpJsonString.isEmpty()) {
|
if(tmpJsonString != null && !tmpJsonString.isEmpty()) {
|
||||||
|
@ -212,7 +219,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
tmpJsonString2 = hmcRestClient.getPcmDataForLogicalPartition(partition);
|
tmpJsonString2 = hmcRestClient.getPcmDataForLogicalPartition(partition);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("getMetricsForPartitions() - getPcmDataForLogicalPartition " + e.getMessage());
|
log.warn("getMetricsForPartitions() - getPcmDataForLogicalPartition error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
if(tmpJsonString2 != null && !tmpJsonString2.isEmpty()) {
|
if(tmpJsonString2 != null && !tmpJsonString2.isEmpty()) {
|
||||||
partition.processMetrics(tmpJsonString2);
|
partition.processMetrics(tmpJsonString2);
|
||||||
|
@ -224,7 +231,7 @@ class HmcInstance implements Runnable {
|
||||||
});
|
});
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("getMetricsForPartitions() " + e.getMessage());
|
log.warn("getMetricsForPartitions() - error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -238,7 +245,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
tmpJsonString = hmcRestClient.getPcmDataForEnergy(system.energy);
|
tmpJsonString = hmcRestClient.getPcmDataForEnergy(system.energy);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("getMetricsForEnergy() " + e.getMessage());
|
log.warn("getMetricsForEnergy() - error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
if(tmpJsonString != null && !tmpJsonString.isEmpty()) {
|
if(tmpJsonString != null && !tmpJsonString.isEmpty()) {
|
||||||
|
@ -254,7 +261,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
systems.forEach((systemId, system) -> influxClient.writeManagedSystem(system));
|
systems.forEach((systemId, system) -> influxClient.writeManagedSystem(system));
|
||||||
} catch (NullPointerException npe) {
|
} catch (NullPointerException npe) {
|
||||||
log.warn("writeMetricsForManagedSystems() - NPE: " + npe.getMessage(), npe);
|
log.warn("writeMetricsForManagedSystems() - NPE: {}", npe.getMessage(), npe);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -263,7 +270,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
partitions.forEach((partitionId, partition) -> influxClient.writeLogicalPartition(partition));
|
partitions.forEach((partitionId, partition) -> influxClient.writeLogicalPartition(partition));
|
||||||
} catch (NullPointerException npe) {
|
} catch (NullPointerException npe) {
|
||||||
log.warn("writeMetricsForLogicalPartitions() - NPE: " + npe.getMessage(), npe);
|
log.warn("writeMetricsForLogicalPartitions() - NPE: {}", npe.getMessage(), npe);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -272,7 +279,7 @@ class HmcInstance implements Runnable {
|
||||||
try {
|
try {
|
||||||
systems.forEach((systemId, system) -> influxClient.writeSystemEnergy(system.energy));
|
systems.forEach((systemId, system) -> influxClient.writeSystemEnergy(system.energy));
|
||||||
} catch (NullPointerException npe) {
|
} catch (NullPointerException npe) {
|
||||||
log.warn("writeMetricsForSystemEnergy() - NPE: " + npe.getMessage(), npe);
|
log.warn("writeMetricsForSystemEnergy() - NPE: {}", npe.getMessage(), npe);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -107,7 +107,7 @@ public class HmcRestClient {
|
||||||
Response response = client.newCall(request).execute();
|
Response response = client.newCall(request).execute();
|
||||||
String responseBody = Objects.requireNonNull(response.body()).string();
|
String responseBody = Objects.requireNonNull(response.body()).string();
|
||||||
if (!response.isSuccessful()) {
|
if (!response.isSuccessful()) {
|
||||||
log.warn("login() - Unexpected response: " + response.code());
|
log.warn("login() - Unexpected response: {}", response.code());
|
||||||
throw new IOException("Unexpected code: " + response);
|
throw new IOException("Unexpected code: " + response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,10 +115,10 @@ public class HmcRestClient {
|
||||||
authToken = doc.select("X-API-Session").text();
|
authToken = doc.select("X-API-Session").text();
|
||||||
log.debug("login() - Auth Token: " + authToken);
|
log.debug("login() - Auth Token: " + authToken);
|
||||||
} catch (MalformedURLException e) {
|
} catch (MalformedURLException e) {
|
||||||
log.error("login() - URL Error: " + e.getMessage());
|
log.error("login() - URL Error: {}", e.getMessage());
|
||||||
throw e;
|
throw e;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("login() - Error: " + e.getMessage());
|
log.error("login() - Error: {}", e.getMessage());
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,7 +146,7 @@ public class HmcRestClient {
|
||||||
try {
|
try {
|
||||||
client.newCall(request).execute();
|
client.newCall(request).execute();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
log.warn("logoff() error: " + e.getMessage());
|
log.warn("logoff() error: {}", e.getMessage());
|
||||||
} finally {
|
} finally {
|
||||||
authToken = null;
|
authToken = null;
|
||||||
}
|
}
|
||||||
|
@ -184,11 +184,11 @@ public class HmcRestClient {
|
||||||
el.select("MachineTypeModelAndSerialNumber > SerialNumber").text()
|
el.select("MachineTypeModelAndSerialNumber > SerialNumber").text()
|
||||||
);
|
);
|
||||||
managedSystemsMap.put(system.id, system);
|
managedSystemsMap.put(system.id, system);
|
||||||
log.debug("getManagedSystems() - Found system: " + system);
|
log.debug("getManagedSystems() - Found system: {}", system);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("getManagedSystems() - xml parse error", e);
|
log.warn("getManagedSystems() - XML parse error", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return managedSystemsMap;
|
return managedSystemsMap;
|
||||||
|
@ -223,11 +223,11 @@ public class HmcRestClient {
|
||||||
system
|
system
|
||||||
);
|
);
|
||||||
partitionMap.put(logicalPartition.id, logicalPartition);
|
partitionMap.put(logicalPartition.id, logicalPartition);
|
||||||
log.debug("getLogicalPartitionsForManagedSystem() - Found partition: " + logicalPartition);
|
log.debug("getLogicalPartitionsForManagedSystem() - Found partition: {}", logicalPartition);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("getLogicalPartitionsForManagedSystem() - xml parse error", e);
|
log.warn("getLogicalPartitionsForManagedSystem() - XML parse error: {}", system, e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return partitionMap;
|
return partitionMap;
|
||||||
|
@ -241,7 +241,7 @@ public class HmcRestClient {
|
||||||
*/
|
*/
|
||||||
String getPcmDataForManagedSystem(ManagedSystem system) throws Exception {
|
String getPcmDataForManagedSystem(ManagedSystem system) throws Exception {
|
||||||
|
|
||||||
log.trace("getPcmDataForManagedSystem() - " + system.id);
|
log.trace("getPcmDataForManagedSystem() - {}", system.id);
|
||||||
URL url = new URL(String.format("%s/rest/api/pcm/ManagedSystem/%s/ProcessedMetrics?NoOfSamples=1", baseUrl, system.id));
|
URL url = new URL(String.format("%s/rest/api/pcm/ManagedSystem/%s/ProcessedMetrics?NoOfSamples=1", baseUrl, system.id));
|
||||||
String responseBody = sendGetRequest(url);
|
String responseBody = sendGetRequest(url);
|
||||||
String jsonBody = null;
|
String jsonBody = null;
|
||||||
|
@ -249,7 +249,7 @@ public class HmcRestClient {
|
||||||
// Do not try to parse empty response
|
// Do not try to parse empty response
|
||||||
if(responseBody == null || responseBody.length() <= 1) {
|
if(responseBody == null || responseBody.length() <= 1) {
|
||||||
responseErrors++;
|
responseErrors++;
|
||||||
log.warn("getPcmDataForManagedSystem() - empty response, skipping: " + system.name);
|
log.warn("getPcmDataForManagedSystem() - empty response, skipping: {}", system.name);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -260,12 +260,12 @@ public class HmcRestClient {
|
||||||
|
|
||||||
if(Objects.requireNonNull(link).attr("type").equals("application/json")) {
|
if(Objects.requireNonNull(link).attr("type").equals("application/json")) {
|
||||||
String href = link.attr("href");
|
String href = link.attr("href");
|
||||||
log.trace("getPcmDataForManagedSystem() - json url: " + href);
|
log.trace("getPcmDataForManagedSystem() - URL: {}", href);
|
||||||
jsonBody = sendGetRequest(new URL(href));
|
jsonBody = sendGetRequest(new URL(href));
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("getPcmDataForManagedSystem() - xml parse error", e);
|
log.warn("getPcmDataForManagedSystem() - XML parse error: {}", system, e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return jsonBody;
|
return jsonBody;
|
||||||
|
@ -279,7 +279,7 @@ public class HmcRestClient {
|
||||||
*/
|
*/
|
||||||
String getPcmDataForLogicalPartition(LogicalPartition partition) throws Exception {
|
String getPcmDataForLogicalPartition(LogicalPartition partition) throws Exception {
|
||||||
|
|
||||||
log.trace(String.format("getPcmDataForLogicalPartition() - %s @ %s", partition.id, partition.system.id));
|
log.trace("getPcmDataForLogicalPartition() - {} @ {}", partition.id, partition.system.id);
|
||||||
URL url = new URL(String.format("%s/rest/api/pcm/ManagedSystem/%s/LogicalPartition/%s/ProcessedMetrics?NoOfSamples=1", baseUrl, partition.system.id, partition.id));
|
URL url = new URL(String.format("%s/rest/api/pcm/ManagedSystem/%s/LogicalPartition/%s/ProcessedMetrics?NoOfSamples=1", baseUrl, partition.system.id, partition.id));
|
||||||
String responseBody = sendGetRequest(url);
|
String responseBody = sendGetRequest(url);
|
||||||
String jsonBody = null;
|
String jsonBody = null;
|
||||||
|
@ -287,7 +287,7 @@ public class HmcRestClient {
|
||||||
// Do not try to parse empty response
|
// Do not try to parse empty response
|
||||||
if(responseBody == null || responseBody.length() <= 1) {
|
if(responseBody == null || responseBody.length() <= 1) {
|
||||||
responseErrors++;
|
responseErrors++;
|
||||||
log.warn("getPcmDataForLogicalPartition() - empty response, skipping: " + partition.name);
|
log.warn("getPcmDataForLogicalPartition() - empty response, skipping: {}", partition.name);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -298,12 +298,12 @@ public class HmcRestClient {
|
||||||
|
|
||||||
if(Objects.requireNonNull(link).attr("type").equals("application/json")) {
|
if(Objects.requireNonNull(link).attr("type").equals("application/json")) {
|
||||||
String href = link.attr("href");
|
String href = link.attr("href");
|
||||||
log.trace("getPcmDataForLogicalPartition() - json url: " + href);
|
log.trace("getPcmDataForLogicalPartition() - URL: {}", href);
|
||||||
jsonBody = sendGetRequest(new URL(href));
|
jsonBody = sendGetRequest(new URL(href));
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("getPcmDataForLogicalPartition() - xml parse error", e);
|
log.warn("getPcmDataForLogicalPartition() - XML parse error: {}", partition.id, e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return jsonBody;
|
return jsonBody;
|
||||||
|
@ -327,7 +327,7 @@ public class HmcRestClient {
|
||||||
// Do not try to parse empty response
|
// Do not try to parse empty response
|
||||||
if(responseBody == null || responseBody.length() <= 1) {
|
if(responseBody == null || responseBody.length() <= 1) {
|
||||||
responseErrors++;
|
responseErrors++;
|
||||||
log.trace("getPcmDataForEnergy() - empty response");
|
log.trace("getPcmDataForEnergy() - empty response, skipping: {}", systemEnergy);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -338,12 +338,12 @@ public class HmcRestClient {
|
||||||
|
|
||||||
if(Objects.requireNonNull(link).attr("type").equals("application/json")) {
|
if(Objects.requireNonNull(link).attr("type").equals("application/json")) {
|
||||||
String href = link.attr("href");
|
String href = link.attr("href");
|
||||||
log.trace("getPcmDataForEnergy() - json url: " + href);
|
log.trace("getPcmDataForEnergy() - URL: {}", href);
|
||||||
jsonBody = sendGetRequest(new URL(href));
|
jsonBody = sendGetRequest(new URL(href));
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("getPcmDataForEnergy() - xml parse error", e);
|
log.warn("getPcmDataForEnergy() - XML parse error: {}", systemEnergy, e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return jsonBody;
|
return jsonBody;
|
||||||
|
@ -356,16 +356,15 @@ public class HmcRestClient {
|
||||||
*/
|
*/
|
||||||
void enableEnergyMonitoring(ManagedSystem system) {
|
void enableEnergyMonitoring(ManagedSystem system) {
|
||||||
|
|
||||||
log.trace("enableEnergyMonitoring() - " + system.id);
|
log.trace("enableEnergyMonitoring() - {}", system);
|
||||||
try {
|
try {
|
||||||
URL url = new URL(String.format("%s/rest/api/pcm/ManagedSystem/%s/preferences", baseUrl, system.id));
|
URL url = new URL(String.format("%s/rest/api/pcm/ManagedSystem/%s/preferences", baseUrl, system.id));
|
||||||
String responseBody = sendGetRequest(url);
|
String responseBody = sendGetRequest(url);
|
||||||
String jsonBody = null;
|
|
||||||
|
|
||||||
// Do not try to parse empty response
|
// Do not try to parse empty response
|
||||||
if(responseBody == null || responseBody.length() <= 1) {
|
if(responseBody == null || responseBody.length() <= 1) {
|
||||||
responseErrors++;
|
responseErrors++;
|
||||||
log.warn("enableEnergyMonitoring() - empty response");
|
log.warn("enableEnergyMonitoring() - empty response, skipping: {}", system);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -396,7 +395,7 @@ public class HmcRestClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("enableEnergyMonitoring() - Exception: " + e.getMessage());
|
log.debug("enableEnergyMonitoring() - Error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -409,7 +408,7 @@ public class HmcRestClient {
|
||||||
*/
|
*/
|
||||||
private String sendGetRequest(URL url) throws Exception {
|
private String sendGetRequest(URL url) throws Exception {
|
||||||
|
|
||||||
log.trace("getResponse() - URL: " + url.toString());
|
log.trace("getResponse() - URL: {}", url.toString());
|
||||||
if(authToken == null) {
|
if(authToken == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -434,7 +433,7 @@ public class HmcRestClient {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
log.error("getResponse() - Unexpected response: " + response.code());
|
log.error("getResponse() - Unexpected response: {}", response.code());
|
||||||
throw new IOException("getResponse() - Unexpected response: " + response.code());
|
throw new IOException("getResponse() - Unexpected response: " + response.code());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -451,7 +450,7 @@ public class HmcRestClient {
|
||||||
*/
|
*/
|
||||||
public String sendPostRequest(URL url, String payload) throws Exception {
|
public String sendPostRequest(URL url, String payload) throws Exception {
|
||||||
|
|
||||||
log.trace("sendPostRequest() - URL: " + url.toString());
|
log.trace("sendPostRequest() - URL: {}", url.toString());
|
||||||
if(authToken == null) {
|
if(authToken == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -478,7 +477,7 @@ public class HmcRestClient {
|
||||||
if (!response.isSuccessful()) {
|
if (!response.isSuccessful()) {
|
||||||
response.close();
|
response.close();
|
||||||
log.warn(body);
|
log.warn(body);
|
||||||
log.error("sendPostRequest() - Unexpected response: " + response.code());
|
log.error("sendPostRequest() - Unexpected response: {}", response.code());
|
||||||
throw new IOException("sendPostRequest() - Unexpected response: " + response.code());
|
throw new IOException("sendPostRequest() - Unexpected response: " + response.code());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@ package biz.nellemann.hmci;
|
||||||
|
|
||||||
import biz.nellemann.hmci.Configuration.InfluxObject;
|
import biz.nellemann.hmci.Configuration.InfluxObject;
|
||||||
import org.influxdb.InfluxDB;
|
import org.influxdb.InfluxDB;
|
||||||
|
import org.influxdb.InfluxDBException;
|
||||||
import org.influxdb.InfluxDBFactory;
|
import org.influxdb.InfluxDBFactory;
|
||||||
import org.influxdb.dto.BatchPoints;
|
import org.influxdb.dto.BatchPoints;
|
||||||
import org.influxdb.dto.Point;
|
import org.influxdb.dto.Point;
|
||||||
|
@ -64,18 +65,18 @@ class InfluxClient {
|
||||||
|
|
||||||
do {
|
do {
|
||||||
try {
|
try {
|
||||||
log.debug("Connecting to InfluxDB - " + url);
|
log.debug("Connecting to InfluxDB - {}", url);
|
||||||
influxDB = InfluxDBFactory.connect(url, username, password);
|
influxDB = InfluxDBFactory.connect(url, username, password).setDatabase(database);
|
||||||
createDatabase();
|
influxDB.version(); // This ensures that we actually try to connect to the db
|
||||||
batchPoints = BatchPoints.database(database).precision(TimeUnit.SECONDS).build();
|
batchPoints = BatchPoints.database(database).precision(TimeUnit.SECONDS).build();
|
||||||
connected = true;
|
connected = true;
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
sleep(15 * 1000);
|
sleep(15 * 1000);
|
||||||
if(loginErrors++ > 3) {
|
if(loginErrors++ > 3) {
|
||||||
log.error("login() error, giving up - " + e.getMessage());
|
log.error("login() - error, giving up: {}", e.getMessage());
|
||||||
throw new RuntimeException(e);
|
throw new RuntimeException(e);
|
||||||
} else {
|
} else {
|
||||||
log.warn("login() error, retrying - " + e.getMessage());
|
log.warn("login() - error, retrying: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} while(!connected);
|
} while(!connected);
|
||||||
|
@ -91,19 +92,19 @@ class InfluxClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void createDatabase() {
|
|
||||||
// Create our database... with a default retention of 156w == 3 years
|
|
||||||
influxDB.query(new Query("CREATE DATABASE " + database + " WITH DURATION 156w"));
|
|
||||||
influxDB.setDatabase(database);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
synchronized void writeBatchPoints() throws Exception {
|
synchronized void writeBatchPoints() throws Exception {
|
||||||
log.debug("writeBatchPoints()");
|
log.trace("writeBatchPoints()");
|
||||||
try {
|
try {
|
||||||
influxDB.writeWithRetry(batchPoints);
|
influxDB.writeWithRetry(batchPoints);
|
||||||
|
errorCounter = 0;
|
||||||
|
} catch (InfluxDBException.DatabaseNotFoundException e) {
|
||||||
|
log.error("writeBatchPoints() - database \"{}\" not found/created: can't write data", database);
|
||||||
|
if(++errorCounter > 3) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.warn("writeBatchPoints() " + e.getMessage());
|
e.printStackTrace();
|
||||||
|
log.warn("writeBatchPoints() {}", e.getMessage());
|
||||||
if(++errorCounter > 5) {
|
if(++errorCounter > 5) {
|
||||||
errorCounter = 0;
|
errorCounter = 0;
|
||||||
logoff();
|
logoff();
|
||||||
|
@ -122,13 +123,13 @@ class InfluxClient {
|
||||||
void writeManagedSystem(ManagedSystem system) {
|
void writeManagedSystem(ManagedSystem system) {
|
||||||
|
|
||||||
if(system.metrics == null) {
|
if(system.metrics == null) {
|
||||||
log.trace("writeManagedSystem() - null metrics, skipping: " + system.name);
|
log.trace("writeManagedSystem() - null metrics, skipping: {}", system.name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Instant timestamp = system.getTimestamp();
|
Instant timestamp = system.getTimestamp();
|
||||||
if(timestamp == null) {
|
if(timestamp == null) {
|
||||||
log.warn("writeManagedSystem() - no timestamp, skipping: " + system.name);
|
log.warn("writeManagedSystem() - no timestamp, skipping: {}", system.name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,13 +254,13 @@ class InfluxClient {
|
||||||
void writeLogicalPartition(LogicalPartition partition) {
|
void writeLogicalPartition(LogicalPartition partition) {
|
||||||
|
|
||||||
if(partition.metrics == null) {
|
if(partition.metrics == null) {
|
||||||
log.warn("writeLogicalPartition() - null metrics, skipping: " + partition.name);
|
log.warn("writeLogicalPartition() - null metrics, skipping: {}", partition.name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Instant timestamp = partition.getTimestamp();
|
Instant timestamp = partition.getTimestamp();
|
||||||
if(timestamp == null) {
|
if(timestamp == null) {
|
||||||
log.warn("writeLogicalPartition() - no timestamp, skipping: " + partition.name);
|
log.warn("writeLogicalPartition() - no timestamp, skipping: {}", partition.name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -314,13 +315,13 @@ class InfluxClient {
|
||||||
void writeSystemEnergy(SystemEnergy systemEnergy) {
|
void writeSystemEnergy(SystemEnergy systemEnergy) {
|
||||||
|
|
||||||
if(systemEnergy.metrics == null) {
|
if(systemEnergy.metrics == null) {
|
||||||
log.trace("writeSystemEnergy() - null metrics, skipping: " + systemEnergy.system.name);
|
log.trace("writeSystemEnergy() - null metrics, skipping: {}", systemEnergy.system.name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Instant timestamp = systemEnergy.getTimestamp();
|
Instant timestamp = systemEnergy.getTimestamp();
|
||||||
if(timestamp == null) {
|
if(timestamp == null) {
|
||||||
log.warn("writeSystemEnergy() - no timestamp, skipping: " + systemEnergy.system.name);
|
log.warn("writeSystemEnergy() - no timestamp, skipping: {}", systemEnergy.system.name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -354,7 +355,7 @@ class InfluxClient {
|
||||||
// Iterate fields
|
// Iterate fields
|
||||||
m.fields.forEach((fieldName, fieldValue) -> {
|
m.fields.forEach((fieldName, fieldValue) -> {
|
||||||
|
|
||||||
log.trace("processMeasurementMap() " + measurement + " - fieldName: " + fieldName + ", fieldValue: " + fieldValue);
|
log.trace("processMeasurementMap() {} - fieldName: {}, fieldValue: {}", measurement, fieldName, fieldValue);
|
||||||
if(fieldValue instanceof Number) {
|
if(fieldValue instanceof Number) {
|
||||||
Number num = (Number) fieldValue;
|
Number num = (Number) fieldValue;
|
||||||
builder.addField(fieldName, num);
|
builder.addField(fieldName, num);
|
||||||
|
@ -369,7 +370,7 @@ class InfluxClient {
|
||||||
|
|
||||||
// Iterate tags
|
// Iterate tags
|
||||||
m.tags.forEach((tagName, tagValue) -> {
|
m.tags.forEach((tagName, tagValue) -> {
|
||||||
log.trace("processMeasurementMap() " + measurement + " - tagName: " + tagName + ", tagValue: " + tagValue);
|
log.trace("processMeasurementMap() {} - tagName: {}, tagValue: {}", measurement, tagName, tagValue);
|
||||||
builder.tag(tagName, tagValue);
|
builder.tag(tagName, tagValue);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
Map<String, String> tagsMap = new HashMap<>();
|
Map<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", system.name);
|
tagsMap.put("servername", system.name);
|
||||||
tagsMap.put("lparname", name);
|
tagsMap.put("lparname", name);
|
||||||
log.trace("getDetails() - tags: " + tagsMap);
|
log.trace("getDetails() - tags: {}", tagsMap);
|
||||||
|
|
||||||
Map<String, Object> fieldsMap = new HashMap<>();
|
Map<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("id", metrics.systemUtil.sample.lparsUtil.id);
|
fieldsMap.put("id", metrics.systemUtil.sample.lparsUtil.id);
|
||||||
|
@ -63,7 +63,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
fieldsMap.put("state", metrics.systemUtil.sample.lparsUtil.state);
|
fieldsMap.put("state", metrics.systemUtil.sample.lparsUtil.state);
|
||||||
fieldsMap.put("osType", metrics.systemUtil.sample.lparsUtil.osType);
|
fieldsMap.put("osType", metrics.systemUtil.sample.lparsUtil.osType);
|
||||||
fieldsMap.put("affinityScore", metrics.systemUtil.sample.lparsUtil.affinityScore);
|
fieldsMap.put("affinityScore", metrics.systemUtil.sample.lparsUtil.affinityScore);
|
||||||
log.trace("getDetails() - fields: " + fieldsMap);
|
log.trace("getDetails() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -78,12 +78,12 @@ class LogicalPartition extends MetaSystem {
|
||||||
Map<String, String> tagsMap = new HashMap<>();
|
Map<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", system.name);
|
tagsMap.put("servername", system.name);
|
||||||
tagsMap.put("lparname", name);
|
tagsMap.put("lparname", name);
|
||||||
log.trace("getMemoryMetrics() - tags: " + tagsMap);
|
log.trace("getMemoryMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
Map<String, Object> fieldsMap = new HashMap<>();
|
Map<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("logicalMem", metrics.systemUtil.sample.lparsUtil.memory.logicalMem);
|
fieldsMap.put("logicalMem", metrics.systemUtil.sample.lparsUtil.memory.logicalMem);
|
||||||
fieldsMap.put("backedPhysicalMem", metrics.systemUtil.sample.lparsUtil.memory.backedPhysicalMem);
|
fieldsMap.put("backedPhysicalMem", metrics.systemUtil.sample.lparsUtil.memory.backedPhysicalMem);
|
||||||
log.trace("getMemoryMetrics() - fields: " + fieldsMap);
|
log.trace("getMemoryMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -98,7 +98,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", system.name);
|
tagsMap.put("servername", system.name);
|
||||||
tagsMap.put("lparname", name);
|
tagsMap.put("lparname", name);
|
||||||
log.trace("getProcessorMetrics() - tags: " + tagsMap);
|
log.trace("getProcessorMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.lparsUtil.processor.utilizedProcUnits);
|
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.lparsUtil.processor.utilizedProcUnits);
|
||||||
|
@ -115,7 +115,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
fieldsMap.put("mode", metrics.systemUtil.sample.lparsUtil.processor.mode);
|
fieldsMap.put("mode", metrics.systemUtil.sample.lparsUtil.processor.mode);
|
||||||
fieldsMap.put("weight", metrics.systemUtil.sample.lparsUtil.processor.weight);
|
fieldsMap.put("weight", metrics.systemUtil.sample.lparsUtil.processor.weight);
|
||||||
fieldsMap.put("poolId", metrics.systemUtil.sample.lparsUtil.processor.poolId);
|
fieldsMap.put("poolId", metrics.systemUtil.sample.lparsUtil.processor.poolId);
|
||||||
log.trace("getProcessorMetrics() - fields: " + fieldsMap);
|
log.trace("getProcessorMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -136,7 +136,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
tagsMap.put("viosId", adapter.viosId.toString());
|
tagsMap.put("viosId", adapter.viosId.toString());
|
||||||
tagsMap.put("vlanId", adapter.vlanId.toString());
|
tagsMap.put("vlanId", adapter.vlanId.toString());
|
||||||
tagsMap.put("vswitchId", adapter.vswitchId.toString());
|
tagsMap.put("vswitchId", adapter.vswitchId.toString());
|
||||||
log.trace("getVirtualEthernetAdapterMetrics() - tags: " + tagsMap);
|
log.trace("getVirtualEthernetAdapterMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
||||||
|
@ -153,7 +153,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
||||||
fieldsMap.put("transferredPhysicalBytes", adapter.transferredPhysicalBytes);
|
fieldsMap.put("transferredPhysicalBytes", adapter.transferredPhysicalBytes);
|
||||||
fieldsMap.put("sharedEthernetAdapterId", adapter.sharedEthernetAdapterId);
|
fieldsMap.put("sharedEthernetAdapterId", adapter.sharedEthernetAdapterId);
|
||||||
log.trace("getVirtualEthernetAdapterMetrics() - fields: " + fieldsMap);
|
log.trace("getVirtualEthernetAdapterMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -174,7 +174,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
tagsMap.put("viosId", adapter.viosId.toString());
|
tagsMap.put("viosId", adapter.viosId.toString());
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
tagsMap.put("id", adapter.id);
|
tagsMap.put("id", adapter.id);
|
||||||
log.trace("getVirtualGenericAdapterMetrics() - tags: " + tagsMap);
|
log.trace("getVirtualGenericAdapterMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("numOfReads", adapter.numOfReads);
|
fieldsMap.put("numOfReads", adapter.numOfReads);
|
||||||
|
@ -182,7 +182,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
fieldsMap.put("writeBytes", adapter.writeBytes);
|
fieldsMap.put("writeBytes", adapter.writeBytes);
|
||||||
fieldsMap.put("readBytes", adapter.readBytes);
|
fieldsMap.put("readBytes", adapter.readBytes);
|
||||||
fieldsMap.put("type", adapter.type);
|
fieldsMap.put("type", adapter.type);
|
||||||
log.trace("getVirtualGenericAdapterMetrics() - fields: " + fieldsMap);
|
log.trace("getVirtualGenericAdapterMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -201,7 +201,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
tagsMap.put("lparname", name);
|
tagsMap.put("lparname", name);
|
||||||
tagsMap.put("viosId", adapter.viosId.toString());
|
tagsMap.put("viosId", adapter.viosId.toString());
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
log.trace("getVirtualFibreChannelAdapterMetrics() - tags: " + tagsMap);
|
log.trace("getVirtualFibreChannelAdapterMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("numOfReads", adapter.numOfReads);
|
fieldsMap.put("numOfReads", adapter.numOfReads);
|
||||||
|
@ -213,7 +213,7 @@ class LogicalPartition extends MetaSystem {
|
||||||
fieldsMap.put("transferredByte", adapter.transmittedBytes); // TODO: Must be error in dashboard, remove when checked.
|
fieldsMap.put("transferredByte", adapter.transmittedBytes); // TODO: Must be error in dashboard, remove when checked.
|
||||||
//fieldsMap.put("wwpn", adapter.wwpn);
|
//fieldsMap.put("wwpn", adapter.wwpn);
|
||||||
//fieldsMap.put("wwpn2", adapter.wwpn2);
|
//fieldsMap.put("wwpn2", adapter.wwpn2);
|
||||||
log.trace("getVirtualFibreChannelAdapterMetrics() - fields: " + fieldsMap);
|
log.trace("getVirtualFibreChannelAdapterMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
|
|
@ -58,7 +58,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
log.trace("getDetails() - tags: " + tagsMap);
|
log.trace("getDetails() - tags: {}", tagsMap);
|
||||||
|
|
||||||
Map<String, Object> fieldsMap = new HashMap<>();
|
Map<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("mtm", String.format("%s-%s %s", type, model, serialNumber));
|
fieldsMap.put("mtm", String.format("%s-%s %s", type, model, serialNumber));
|
||||||
|
@ -69,7 +69,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("name", name);
|
fieldsMap.put("name", name);
|
||||||
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.systemFirmwareUtil.utilizedProcUnits);
|
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.systemFirmwareUtil.utilizedProcUnits);
|
||||||
fieldsMap.put("assignedMem", metrics.systemUtil.sample.systemFirmwareUtil.assignedMem);
|
fieldsMap.put("assignedMem", metrics.systemUtil.sample.systemFirmwareUtil.assignedMem);
|
||||||
log.trace("getDetails() - fields: " + fieldsMap);
|
log.trace("getDetails() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -83,7 +83,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
log.trace("getMemoryMetrics() - tags: " + tagsMap);
|
log.trace("getMemoryMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
Map<String, Object> fieldsMap = new HashMap<>();
|
Map<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("totalMem", metrics.systemUtil.sample.serverUtil.memory.totalMem);
|
fieldsMap.put("totalMem", metrics.systemUtil.sample.serverUtil.memory.totalMem);
|
||||||
|
@ -91,7 +91,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("configurableMem", metrics.systemUtil.sample.serverUtil.memory.configurableMem);
|
fieldsMap.put("configurableMem", metrics.systemUtil.sample.serverUtil.memory.configurableMem);
|
||||||
fieldsMap.put("assignedMemToLpars", metrics.systemUtil.sample.serverUtil.memory.assignedMemToLpars);
|
fieldsMap.put("assignedMemToLpars", metrics.systemUtil.sample.serverUtil.memory.assignedMemToLpars);
|
||||||
fieldsMap.put("virtualPersistentMem", metrics.systemUtil.sample.serverUtil.memory.virtualPersistentMem);
|
fieldsMap.put("virtualPersistentMem", metrics.systemUtil.sample.serverUtil.memory.virtualPersistentMem);
|
||||||
log.trace("getMemoryMetrics() - fields: " + fieldsMap);
|
log.trace("getMemoryMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -105,14 +105,14 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
log.trace("getProcessorMetrics() - tags: " + tagsMap);
|
log.trace("getProcessorMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("totalProcUnits", metrics.systemUtil.sample.serverUtil.processor.totalProcUnits);
|
fieldsMap.put("totalProcUnits", metrics.systemUtil.sample.serverUtil.processor.totalProcUnits);
|
||||||
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.serverUtil.processor.utilizedProcUnits);
|
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.serverUtil.processor.utilizedProcUnits);
|
||||||
fieldsMap.put("availableProcUnits", metrics.systemUtil.sample.serverUtil.processor.availableProcUnits);
|
fieldsMap.put("availableProcUnits", metrics.systemUtil.sample.serverUtil.processor.availableProcUnits);
|
||||||
fieldsMap.put("configurableProcUnits", metrics.systemUtil.sample.serverUtil.processor.configurableProcUnits);
|
fieldsMap.put("configurableProcUnits", metrics.systemUtil.sample.serverUtil.processor.configurableProcUnits);
|
||||||
log.trace("getProcessorMetrics() - fields: " + fieldsMap);
|
log.trace("getProcessorMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -128,7 +128,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("pool", sharedProcessorPool.id);
|
tagsMap.put("pool", sharedProcessorPool.id);
|
||||||
tagsMap.put("poolname", sharedProcessorPool.name);
|
tagsMap.put("poolname", sharedProcessorPool.name);
|
||||||
log.trace("getSharedProcessorPools() - tags: " + tagsMap);
|
log.trace("getSharedProcessorPools() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("assignedProcUnits", sharedProcessorPool.assignedProcUnits);
|
fieldsMap.put("assignedProcUnits", sharedProcessorPool.assignedProcUnits);
|
||||||
|
@ -136,7 +136,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("utilizedProcUnits", sharedProcessorPool.utilizedProcUnits);
|
fieldsMap.put("utilizedProcUnits", sharedProcessorPool.utilizedProcUnits);
|
||||||
fieldsMap.put("borrowedProcUnits", sharedProcessorPool.borrowedProcUnits);
|
fieldsMap.put("borrowedProcUnits", sharedProcessorPool.borrowedProcUnits);
|
||||||
fieldsMap.put("configuredProcUnits", sharedProcessorPool.configuredProcUnits);
|
fieldsMap.put("configuredProcUnits", sharedProcessorPool.configuredProcUnits);
|
||||||
log.trace("getSharedProcessorPools() - fields: " + fieldsMap);
|
log.trace("getSharedProcessorPools() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -152,7 +152,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
log.trace("getPhysicalProcessorPool() - tags: " + tagsMap);
|
log.trace("getPhysicalProcessorPool() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("assignedProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.assignedProcUnits);
|
fieldsMap.put("assignedProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.assignedProcUnits);
|
||||||
|
@ -160,7 +160,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.utilizedProcUnits);
|
fieldsMap.put("utilizedProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.utilizedProcUnits);
|
||||||
fieldsMap.put("configuredProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.configuredProcUnits);
|
fieldsMap.put("configuredProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.configuredProcUnits);
|
||||||
fieldsMap.put("borrowedProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.borrowedProcUnits);
|
fieldsMap.put("borrowedProcUnits", metrics.systemUtil.sample.serverUtil.physicalProcessorPool.borrowedProcUnits);
|
||||||
log.trace("getPhysicalProcessorPool() - fields: " + fieldsMap);
|
log.trace("getPhysicalProcessorPool() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -176,14 +176,14 @@ class ManagedSystem extends MetaSystem {
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
log.trace("getViosDetails() - tags: " + tagsMap);
|
log.trace("getViosDetails() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("viosid", vios.id);
|
fieldsMap.put("viosid", vios.id);
|
||||||
fieldsMap.put("viosstate", vios.state);
|
fieldsMap.put("viosstate", vios.state);
|
||||||
fieldsMap.put("viosname", vios.name);
|
fieldsMap.put("viosname", vios.name);
|
||||||
fieldsMap.put("affinityScore", vios.affinityScore);
|
fieldsMap.put("affinityScore", vios.affinityScore);
|
||||||
log.trace("getViosDetails() - fields: " + fieldsMap);
|
log.trace("getViosDetails() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -201,7 +201,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
log.trace("getViosMemoryMetrics() - tags: " + tagsMap);
|
log.trace("getViosMemoryMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
Number assignedMem = getNumberMetricObject(vios.memory.assignedMem);
|
Number assignedMem = getNumberMetricObject(vios.memory.assignedMem);
|
||||||
|
@ -216,7 +216,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
Number usedMemPct = (utilizedMem.intValue() * 100 ) / assignedMem.intValue();
|
Number usedMemPct = (utilizedMem.intValue() * 100 ) / assignedMem.intValue();
|
||||||
fieldsMap.put("utilizedPct", usedMemPct.floatValue());
|
fieldsMap.put("utilizedPct", usedMemPct.floatValue());
|
||||||
}
|
}
|
||||||
log.trace("getViosMemoryMetrics() - fields: " + fieldsMap);
|
log.trace("getViosMemoryMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -234,7 +234,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
log.trace("getViosProcessorMetrics() - tags: " + tagsMap);
|
log.trace("getViosProcessorMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("utilizedProcUnits", vios.processor.utilizedProcUnits);
|
fieldsMap.put("utilizedProcUnits", vios.processor.utilizedProcUnits);
|
||||||
|
@ -250,7 +250,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("timePerInstructionExecution", vios.processor.timeSpentWaitingForDispatch);
|
fieldsMap.put("timePerInstructionExecution", vios.processor.timeSpentWaitingForDispatch);
|
||||||
fieldsMap.put("weight", vios.processor.weight);
|
fieldsMap.put("weight", vios.processor.weight);
|
||||||
fieldsMap.put("mode", vios.processor.mode);
|
fieldsMap.put("mode", vios.processor.mode);
|
||||||
log.trace("getViosProcessorMetrics() - fields: " + fieldsMap);
|
log.trace("getViosProcessorMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -268,11 +268,11 @@ class ManagedSystem extends MetaSystem {
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
log.trace("getViosNetworkLpars() - tags: " + tagsMap);
|
log.trace("getViosNetworkLpars() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("clientlpars", vios.network.clientLpars.size());
|
fieldsMap.put("clientlpars", vios.network.clientLpars.size());
|
||||||
log.trace("getViosNetworkLpars() - fields: " + fieldsMap);
|
log.trace("getViosNetworkLpars() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -294,7 +294,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
//tagsMap.put("id", adapter.id);
|
//tagsMap.put("id", adapter.id);
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
log.trace("getViosNetworkSharedAdapters() - tags: " + tagsMap);
|
log.trace("getViosNetworkSharedAdapters() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("id", adapter.id);
|
fieldsMap.put("id", adapter.id);
|
||||||
|
@ -305,7 +305,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("receivedPackets", adapter.receivedPackets);
|
fieldsMap.put("receivedPackets", adapter.receivedPackets);
|
||||||
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
||||||
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
||||||
log.trace("getViosNetworkSharedAdapters() - fields: " + fieldsMap);
|
log.trace("getViosNetworkSharedAdapters() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -331,7 +331,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("systemname", name);
|
tagsMap.put("systemname", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
log.trace("getViosNetworkVirtualAdapters() - tags: " + tagsMap);
|
log.trace("getViosNetworkVirtualAdapters() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
||||||
|
@ -347,7 +347,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("sentPhysicalPackets", adapter.sentPhysicalPackets);
|
fieldsMap.put("sentPhysicalPackets", adapter.sentPhysicalPackets);
|
||||||
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
||||||
fieldsMap.put("transferredPhysicalBytes", adapter.transferredPhysicalBytes);
|
fieldsMap.put("transferredPhysicalBytes", adapter.transferredPhysicalBytes);
|
||||||
log.trace("getViosNetworkVirtualAdapters() - fields: " + fieldsMap);
|
log.trace("getViosNetworkVirtualAdapters() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -372,7 +372,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
log.trace("getViosNetworkGenericAdapters() - tags: " + tagsMap);
|
log.trace("getViosNetworkGenericAdapters() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("sentBytes", adapter.sentBytes);
|
fieldsMap.put("sentBytes", adapter.sentBytes);
|
||||||
|
@ -381,7 +381,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("receivedPackets", adapter.receivedPackets);
|
fieldsMap.put("receivedPackets", adapter.receivedPackets);
|
||||||
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
fieldsMap.put("droppedPackets", adapter.droppedPackets);
|
||||||
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
fieldsMap.put("transferredBytes", adapter.transferredBytes);
|
||||||
log.trace("getViosNetworkGenericAdapters() - fields: " + fieldsMap);
|
log.trace("getViosNetworkGenericAdapters() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -400,11 +400,11 @@ class ManagedSystem extends MetaSystem {
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
log.trace("getViosStorageLpars() - tags: " + tagsMap);
|
log.trace("getViosStorageLpars() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("clientlpars", vios.storage.clientLpars.size());
|
fieldsMap.put("clientlpars", vios.storage.clientLpars.size());
|
||||||
log.trace("getViosStorageLpars() - fields: " + fieldsMap);
|
log.trace("getViosStorageLpars() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -417,7 +417,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
List<Measurement> list = new ArrayList<>();
|
List<Measurement> list = new ArrayList<>();
|
||||||
metrics.systemUtil.sample.viosUtil.forEach( vios -> {
|
metrics.systemUtil.sample.viosUtil.forEach( vios -> {
|
||||||
log.trace("getViosStorageFiberChannelAdapters() - VIOS: " + vios.name);
|
log.trace("getViosStorageFiberChannelAdapters() - VIOS: {}", vios.name);
|
||||||
|
|
||||||
vios.storage.fiberChannelAdapters.forEach( adapter -> {
|
vios.storage.fiberChannelAdapters.forEach( adapter -> {
|
||||||
|
|
||||||
|
@ -426,7 +426,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("servername", name);
|
tagsMap.put("servername", name);
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
log.trace("getViosStorageFiberChannelAdapters() - tags: " + tagsMap);
|
log.trace("getViosStorageFiberChannelAdapters() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("numOfReads", adapter.numOfReads);
|
fieldsMap.put("numOfReads", adapter.numOfReads);
|
||||||
|
@ -434,7 +434,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("readBytes", adapter.readBytes);
|
fieldsMap.put("readBytes", adapter.readBytes);
|
||||||
fieldsMap.put("writeBytes", adapter.writeBytes);
|
fieldsMap.put("writeBytes", adapter.writeBytes);
|
||||||
fieldsMap.put("transmittedBytes", adapter.transmittedBytes);
|
fieldsMap.put("transmittedBytes", adapter.transmittedBytes);
|
||||||
log.trace("getViosStorageFiberChannelAdapters() - fields: " + fieldsMap);
|
log.trace("getViosStorageFiberChannelAdapters() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -483,7 +483,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
List<Measurement> list = new ArrayList<>();
|
List<Measurement> list = new ArrayList<>();
|
||||||
metrics.systemUtil.sample.viosUtil.forEach( vios -> {
|
metrics.systemUtil.sample.viosUtil.forEach( vios -> {
|
||||||
log.trace("getViosStoragePhysicalAdapters() - VIOS: " + vios.name);
|
log.trace("getViosStoragePhysicalAdapters() - VIOS: {}", vios.name);
|
||||||
|
|
||||||
vios.storage.genericPhysicalAdapters.forEach( adapter -> {
|
vios.storage.genericPhysicalAdapters.forEach( adapter -> {
|
||||||
|
|
||||||
|
@ -492,7 +492,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
tagsMap.put("id", adapter.id);
|
tagsMap.put("id", adapter.id);
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
log.trace("getViosStoragePhysicalAdapters() - tags: " + tagsMap);
|
log.trace("getViosStoragePhysicalAdapters() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("numOfReads", adapter.numOfReads);
|
fieldsMap.put("numOfReads", adapter.numOfReads);
|
||||||
|
@ -501,7 +501,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("writeBytes", adapter.writeBytes);
|
fieldsMap.put("writeBytes", adapter.writeBytes);
|
||||||
fieldsMap.put("transmittedBytes", adapter.transmittedBytes);
|
fieldsMap.put("transmittedBytes", adapter.transmittedBytes);
|
||||||
fieldsMap.put("type", adapter.type);
|
fieldsMap.put("type", adapter.type);
|
||||||
log.trace("getViosStoragePhysicalAdapters() - fields: " + fieldsMap);
|
log.trace("getViosStoragePhysicalAdapters() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
@ -517,7 +517,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
|
|
||||||
List<Measurement> list = new ArrayList<>();
|
List<Measurement> list = new ArrayList<>();
|
||||||
metrics.systemUtil.sample.viosUtil.forEach( vios -> {
|
metrics.systemUtil.sample.viosUtil.forEach( vios -> {
|
||||||
log.trace("getViosStorageVirtualAdapters() - VIOS: " + vios.name);
|
log.trace("getViosStorageVirtualAdapters() - VIOS: {}", vios.name);
|
||||||
|
|
||||||
vios.storage.genericVirtualAdapters.forEach( adapter -> {
|
vios.storage.genericVirtualAdapters.forEach( adapter -> {
|
||||||
|
|
||||||
|
@ -526,7 +526,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
tagsMap.put("viosname", vios.name);
|
tagsMap.put("viosname", vios.name);
|
||||||
tagsMap.put("location", adapter.physicalLocation);
|
tagsMap.put("location", adapter.physicalLocation);
|
||||||
tagsMap.put("id", adapter.id);
|
tagsMap.put("id", adapter.id);
|
||||||
log.trace("getViosStorageVirtualAdapters() - tags: " + tagsMap);
|
log.trace("getViosStorageVirtualAdapters() - tags: {}", tagsMap);
|
||||||
|
|
||||||
HashMap<String, Object> fieldsMap = new HashMap<>();
|
HashMap<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("numOfReads", adapter.numOfReads);
|
fieldsMap.put("numOfReads", adapter.numOfReads);
|
||||||
|
@ -535,7 +535,7 @@ class ManagedSystem extends MetaSystem {
|
||||||
fieldsMap.put("writeBytes", adapter.writeBytes);
|
fieldsMap.put("writeBytes", adapter.writeBytes);
|
||||||
fieldsMap.put("transmittedBytes", adapter.transmittedBytes);
|
fieldsMap.put("transmittedBytes", adapter.transmittedBytes);
|
||||||
fieldsMap.put("type", adapter.type);
|
fieldsMap.put("type", adapter.type);
|
||||||
log.trace("getViosStorageVirtualAdapters() - fields: " + fieldsMap);
|
log.trace("getViosStorageVirtualAdapters() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
});
|
});
|
||||||
|
|
|
@ -66,12 +66,12 @@ abstract class MetaSystem {
|
||||||
String timestamp = getStringMetricObject(metrics.systemUtil.sample.sampleInfo.timeStamp);
|
String timestamp = getStringMetricObject(metrics.systemUtil.sample.sampleInfo.timeStamp);
|
||||||
Instant instant = Instant.now();
|
Instant instant = Instant.now();
|
||||||
try {
|
try {
|
||||||
log.trace("getTimeStamp() - PMC Timestamp: " + timestamp);
|
log.trace("getTimeStamp() - PMC Timestamp: {}", timestamp);
|
||||||
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss[XXX][X]");
|
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss[XXX][X]");
|
||||||
instant = Instant.from(dateTimeFormatter.parse(timestamp));
|
instant = Instant.from(dateTimeFormatter.parse(timestamp));
|
||||||
log.trace("getTimestamp() - Instant: " + instant.toString());
|
log.trace("getTimestamp() - Instant: {}", instant.toString());
|
||||||
} catch(DateTimeParseException e) {
|
} catch(DateTimeParseException e) {
|
||||||
log.warn("getTimestamp() - parse error: " + timestamp);
|
log.warn("getTimestamp() - parse error: {}", timestamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
return instant;
|
return instant;
|
||||||
|
|
|
@ -48,11 +48,11 @@ class SystemEnergy extends MetaSystem {
|
||||||
|
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", system.name);
|
tagsMap.put("servername", system.name);
|
||||||
log.trace("getPowerMetrics() - tags: " + tagsMap);
|
log.trace("getPowerMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
Map<String, Object> fieldsMap = new HashMap<>();
|
Map<String, Object> fieldsMap = new HashMap<>();
|
||||||
fieldsMap.put("powerReading", metrics.systemUtil.sample.energyUtil.powerUtil.powerReading);
|
fieldsMap.put("powerReading", metrics.systemUtil.sample.energyUtil.powerUtil.powerReading);
|
||||||
log.trace("getPowerMetrics() - fields: " + fieldsMap);
|
log.trace("getPowerMetrics() - fields: {}", fieldsMap);
|
||||||
|
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
|
@ -65,7 +65,7 @@ class SystemEnergy extends MetaSystem {
|
||||||
|
|
||||||
HashMap<String, String> tagsMap = new HashMap<>();
|
HashMap<String, String> tagsMap = new HashMap<>();
|
||||||
tagsMap.put("servername", system.name);
|
tagsMap.put("servername", system.name);
|
||||||
log.trace("getThermalMetrics() - tags: " + tagsMap);
|
log.trace("getThermalMetrics() - tags: {}", tagsMap);
|
||||||
|
|
||||||
Map<String, Object> fieldsMap = new HashMap<>();
|
Map<String, Object> fieldsMap = new HashMap<>();
|
||||||
|
|
||||||
|
@ -82,7 +82,7 @@ class SystemEnergy extends MetaSystem {
|
||||||
fieldsMap.put("baseboardTemperature_" + t.entityInstance, t.temperatureReading);
|
fieldsMap.put("baseboardTemperature_" + t.entityInstance, t.temperatureReading);
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
log.trace("getThermalMetrics() - fields: " + fieldsMap);
|
log.trace("getThermalMetrics() - fields: {}", fieldsMap);
|
||||||
list.add(new Measurement(tagsMap, fieldsMap));
|
list.add(new Measurement(tagsMap, fieldsMap));
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ class ConfigurationTest extends Specification {
|
||||||
|
|
||||||
Path testConfigurationFile = Paths.get(getClass().getResource('/hmci.toml').toURI())
|
Path testConfigurationFile = Paths.get(getClass().getResource('/hmci.toml').toURI())
|
||||||
|
|
||||||
void "test parsing"() {
|
void "test parsing of configuration file"() {
|
||||||
|
|
||||||
when:
|
when:
|
||||||
Configuration conf = new Configuration(testConfigurationFile)
|
Configuration conf = new Configuration(testConfigurationFile)
|
||||||
|
@ -20,13 +20,13 @@ class ConfigurationTest extends Specification {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void "test lookup influx"() {
|
void "test energy flag, default setting"() {
|
||||||
|
|
||||||
when:
|
when:
|
||||||
Configuration conf = new Configuration(testConfigurationFile)
|
Configuration conf = new Configuration(testConfigurationFile)
|
||||||
|
|
||||||
then:
|
then:
|
||||||
conf != null
|
!conf.getHmc().get(0).energy
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,21 +13,19 @@ username = "root"
|
||||||
password = ""
|
password = ""
|
||||||
database = "hmci"
|
database = "hmci"
|
||||||
|
|
||||||
|
# HMC on our primary site
|
||||||
|
[hmc.site1]
|
||||||
|
url = "https://10.10.10.10:12443"
|
||||||
|
username = "hmci"
|
||||||
|
password = "hmcihmci"
|
||||||
|
unsafe = true # Ignore SSL cert. errors
|
||||||
|
energy = false # Do not try to collect energy metrics
|
||||||
|
|
||||||
# One or more HMC's to query for data and metrics
|
# Example
|
||||||
[hmc]
|
#[hmc.site2]
|
||||||
|
#url = "https://10.10.20.20:12443"
|
||||||
# HMC on our primary site
|
#username = "viewer"
|
||||||
[hmc.site1]
|
#password = "someSecret"
|
||||||
url = "https://10.10.10.10:12443"
|
#unsafe = false
|
||||||
username = "hmci"
|
#energy = true
|
||||||
password = "hmcihmci"
|
#trace = "/tmp/pcm-files"
|
||||||
unsafe = true # Ignore SSL cert. errors
|
|
||||||
|
|
||||||
# Example
|
|
||||||
#[hmc.site2]
|
|
||||||
#url = "https://10.10.20.20:12443"
|
|
||||||
#username = "viewer"
|
|
||||||
#password = "someSecret"
|
|
||||||
#unsafe = false
|
|
||||||
#trace = "/tmp/pcm-files"
|
|
||||||
|
|
Loading…
Reference in a new issue