mirror of
https://github.com/apache/nifi.git
synced 2025-02-18 07:56:56 +00:00
NIFI-1298: - Addressing too many significant digits in the processor load average and [non]heap utilization.
Signed-off-by: joewitt <joewitt@apache.org>
This commit is contained in:
parent
0436383f49
commit
43c7ecd221
@ -150,12 +150,20 @@ public class SystemDiagnostics implements Cloneable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public int getHeapUtilization() {
|
public int getHeapUtilization() {
|
||||||
|
if (maxHeap == -1) {
|
||||||
|
return -1;
|
||||||
|
} else {
|
||||||
return DiagnosticUtils.getUtilization(usedHeap, maxHeap);
|
return DiagnosticUtils.getUtilization(usedHeap, maxHeap);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public int getNonHeapUtilization() {
|
public int getNonHeapUtilization() {
|
||||||
|
if (maxNonHeap == -1) {
|
||||||
|
return -1;
|
||||||
|
} else {
|
||||||
return DiagnosticUtils.getUtilization(usedNonHeap, maxNonHeap);
|
return DiagnosticUtils.getUtilization(usedNonHeap, maxNonHeap);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Map<String, GarbageCollection> getGarbageCollection() {
|
public Map<String, GarbageCollection> getGarbageCollection() {
|
||||||
return garbageCollection;
|
return garbageCollection;
|
||||||
|
@ -1735,14 +1735,18 @@ public final class DtoFactory {
|
|||||||
dto.setTotalHeap(FormatUtils.formatDataSize(sysDiagnostics.getTotalHeap()));
|
dto.setTotalHeap(FormatUtils.formatDataSize(sysDiagnostics.getTotalHeap()));
|
||||||
dto.setUsedHeap(FormatUtils.formatDataSize(sysDiagnostics.getUsedHeap()));
|
dto.setUsedHeap(FormatUtils.formatDataSize(sysDiagnostics.getUsedHeap()));
|
||||||
dto.setFreeHeap(FormatUtils.formatDataSize(sysDiagnostics.getFreeHeap()));
|
dto.setFreeHeap(FormatUtils.formatDataSize(sysDiagnostics.getFreeHeap()));
|
||||||
|
if (sysDiagnostics.getHeapUtilization() != -1) {
|
||||||
dto.setHeapUtilization(FormatUtils.formatUtilization(sysDiagnostics.getHeapUtilization()));
|
dto.setHeapUtilization(FormatUtils.formatUtilization(sysDiagnostics.getHeapUtilization()));
|
||||||
|
}
|
||||||
|
|
||||||
// non heap
|
// non heap
|
||||||
dto.setMaxNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getMaxNonHeap()));
|
dto.setMaxNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getMaxNonHeap()));
|
||||||
dto.setTotalNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getTotalNonHeap()));
|
dto.setTotalNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getTotalNonHeap()));
|
||||||
dto.setUsedNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getUsedNonHeap()));
|
dto.setUsedNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getUsedNonHeap()));
|
||||||
dto.setFreeNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getFreeNonHeap()));
|
dto.setFreeNonHeap(FormatUtils.formatDataSize(sysDiagnostics.getFreeNonHeap()));
|
||||||
|
if (sysDiagnostics.getNonHeapUtilization() != -1) {
|
||||||
dto.setNonHeapUtilization(FormatUtils.formatUtilization(sysDiagnostics.getNonHeapUtilization()));
|
dto.setNonHeapUtilization(FormatUtils.formatUtilization(sysDiagnostics.getNonHeapUtilization()));
|
||||||
|
}
|
||||||
|
|
||||||
// flow file disk usage
|
// flow file disk usage
|
||||||
final SystemDiagnosticsDTO.StorageUsageDTO flowFileRepositoryStorageUsageDto = createStorageUsageDTO(null, sysDiagnostics.getFlowFileRepositoryStorageUsage());
|
final SystemDiagnosticsDTO.StorageUsageDTO flowFileRepositoryStorageUsageDto = createStorageUsageDTO(null, sysDiagnostics.getFlowFileRepositoryStorageUsage());
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
<div class="settings-left">
|
<div class="settings-left">
|
||||||
<div class="setting">
|
<div class="setting">
|
||||||
<input type="hidden" id=""/>
|
<input type="hidden" id=""/>
|
||||||
<div class="setting-name">Heap (<span id="utilization-heap"></span>)</div>
|
<div class="setting-name">Heap <span id="utilization-heap"></span></div>
|
||||||
<div class="setting-field">
|
<div class="setting-field">
|
||||||
<table id="heap-table">
|
<table id="heap-table">
|
||||||
<tbody>
|
<tbody>
|
||||||
@ -57,7 +57,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="settings-right">
|
<div class="settings-right">
|
||||||
<div class="setting">
|
<div class="setting">
|
||||||
<div class="setting-name">Non heap (<span id="utilization-non-heap"></span>)</div>
|
<div class="setting-name">Non heap <span id="utilization-non-heap"></span></div>
|
||||||
<div class="setting-field">
|
<div class="setting-field">
|
||||||
<table id="heap-table">
|
<table id="heap-table">
|
||||||
<tbody>
|
<tbody>
|
||||||
|
@ -1999,14 +1999,26 @@ nf.SummaryTable = (function () {
|
|||||||
$('#total-heap').text(systemDiagnostics.totalHeap);
|
$('#total-heap').text(systemDiagnostics.totalHeap);
|
||||||
$('#used-heap').text(systemDiagnostics.usedHeap);
|
$('#used-heap').text(systemDiagnostics.usedHeap);
|
||||||
$('#free-heap').text(systemDiagnostics.freeHeap);
|
$('#free-heap').text(systemDiagnostics.freeHeap);
|
||||||
$('#utilization-heap').text(systemDiagnostics.heapUtilization);
|
|
||||||
|
// ensure the heap utilization could be calculated
|
||||||
|
if (nf.Common.isDefinedAndNotNull(systemDiagnostics.heapUtilization)) {
|
||||||
|
$('#utilization-heap').text('(' + systemDiagnostics.heapUtilization + ')');
|
||||||
|
} else {
|
||||||
|
$('#utilization-heap').text('');
|
||||||
|
}
|
||||||
|
|
||||||
// non heap
|
// non heap
|
||||||
$('#max-non-heap').text(systemDiagnostics.maxNonHeap);
|
$('#max-non-heap').text(systemDiagnostics.maxNonHeap);
|
||||||
$('#total-non-heap').text(systemDiagnostics.totalNonHeap);
|
$('#total-non-heap').text(systemDiagnostics.totalNonHeap);
|
||||||
$('#used-non-heap').text(systemDiagnostics.usedNonHeap);
|
$('#used-non-heap').text(systemDiagnostics.usedNonHeap);
|
||||||
$('#free-non-heap').text(systemDiagnostics.freeNonHeap);
|
$('#free-non-heap').text(systemDiagnostics.freeNonHeap);
|
||||||
$('#utilization-non-heap').text(systemDiagnostics.nonHeapUtilization);
|
|
||||||
|
// enure the non heap utilization could be calculated
|
||||||
|
if (nf.Common.isDefinedAndNotNull(systemDiagnostics.nonHeapUtilization)) {
|
||||||
|
$('#utilization-non-heap').text('(' + systemDiagnostics.nonHeapUtilization + ')');
|
||||||
|
} else {
|
||||||
|
$('#utilization-non-heap').text('');
|
||||||
|
}
|
||||||
|
|
||||||
// garbage collection
|
// garbage collection
|
||||||
var garbageCollectionContainer = $('#garbage-collection-table tbody').empty();
|
var garbageCollectionContainer = $('#garbage-collection-table tbody').empty();
|
||||||
@ -2014,9 +2026,15 @@ nf.SummaryTable = (function () {
|
|||||||
addGarbageCollection(garbageCollectionContainer, garbageCollection);
|
addGarbageCollection(garbageCollectionContainer, garbageCollection);
|
||||||
});
|
});
|
||||||
|
|
||||||
// load
|
// available processors
|
||||||
$('#available-processors').text(systemDiagnostics.availableProcessors);
|
$('#available-processors').text(systemDiagnostics.availableProcessors);
|
||||||
|
|
||||||
|
// load
|
||||||
|
if (nf.Common.isDefinedAndNotNull(systemDiagnostics.processorLoadAverage)) {
|
||||||
|
$('#processor-load-average').text(nf.Common.formatFloat(systemDiagnostics.processorLoadAverage));
|
||||||
|
} else {
|
||||||
$('#processor-load-average').html(nf.Common.formatValue(systemDiagnostics.processorLoadAverage));
|
$('#processor-load-average').html(nf.Common.formatValue(systemDiagnostics.processorLoadAverage));
|
||||||
|
}
|
||||||
|
|
||||||
// database storage usage
|
// database storage usage
|
||||||
var flowFileRepositoryStorageUsageContainer = $('#flow-file-repository-storage-usage-container').empty();
|
var flowFileRepositoryStorageUsageContainer = $('#flow-file-repository-storage-usage-container').empty();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user