|
@@ -9,8 +9,10 @@ import javax.inject.Inject;
|
|
|
import javafx.animation.Animation;
|
|
|
import javafx.animation.KeyFrame;
|
|
|
import javafx.animation.Timeline;
|
|
|
+import javafx.beans.binding.Bindings;
|
|
|
import javafx.beans.binding.DoubleBinding;
|
|
|
import javafx.beans.binding.LongBinding;
|
|
|
+import javafx.beans.property.LongProperty;
|
|
|
import javafx.event.ActionEvent;
|
|
|
import javafx.event.EventHandler;
|
|
|
import javafx.fxml.FXML;
|
|
@@ -21,6 +23,7 @@ import javafx.scene.chart.XYChart.Series;
|
|
|
import javafx.stage.Stage;
|
|
|
import javafx.util.Duration;
|
|
|
import java.util.Arrays;
|
|
|
+import java.util.concurrent.Callable;
|
|
|
|
|
|
@VaultStatisticsScoped
|
|
|
public class VaultStatisticsController implements FxController {
|
|
@@ -32,6 +35,7 @@ public class VaultStatisticsController implements FxController {
|
|
|
private final VaultStats stats;
|
|
|
private final Series<Number, Number> readData;
|
|
|
private final Series<Number, Number> writeData;
|
|
|
+ private final Series<Number, Number> accessData;
|
|
|
private final Timeline ioAnimation;
|
|
|
private final LongBinding bpsRead;
|
|
|
private final LongBinding bpsWritten;
|
|
@@ -44,15 +48,20 @@ public class VaultStatisticsController implements FxController {
|
|
|
private final LongBinding totalBytesDecrypted;
|
|
|
private final LongBinding filesRead;
|
|
|
private final LongBinding filesWritten;
|
|
|
+ private final LongBinding filesAccessed;
|
|
|
+ private final LongBinding totalFilesAccessed;
|
|
|
private final LongBinding bpsEncrypted;
|
|
|
private final LongBinding bpsDecrypted;
|
|
|
|
|
|
public AreaChart<Number, Number> readChart;
|
|
|
public AreaChart<Number, Number> writeChart;
|
|
|
+ public AreaChart<Number, Number> accessChart;
|
|
|
public NumberAxis readChartXAxis;
|
|
|
public NumberAxis readChartYAxis;
|
|
|
public NumberAxis writeChartXAxis;
|
|
|
public NumberAxis writeChartYAxis;
|
|
|
+ public NumberAxis accessChartXAxis;
|
|
|
+ public NumberAxis accessChartYAxis;
|
|
|
|
|
|
@Inject
|
|
|
public VaultStatisticsController(VaultStatisticsComponent component, @VaultStatisticsWindow Stage window, @VaultStatisticsWindow Vault vault) {
|
|
@@ -60,6 +69,7 @@ public class VaultStatisticsController implements FxController {
|
|
|
this.stats = vault.getStats();
|
|
|
this.readData = new Series<>();
|
|
|
this.writeData = new Series<>();
|
|
|
+ this.accessData = new Series<>();
|
|
|
this.bpsRead = WeakBindings.bindLong(stats.bytesPerSecondReadProperty());
|
|
|
this.bpsWritten = WeakBindings.bindLong(stats.bytesPerSecondWrittenProperty());
|
|
|
this.cacheHitRate = WeakBindings.bindDouble(stats.cacheHitRateProperty());
|
|
@@ -71,11 +81,13 @@ public class VaultStatisticsController implements FxController {
|
|
|
this.totalBytesEncrypted = WeakBindings.bindLong(stats.totalBytesEncryptedProperty());
|
|
|
this.filesRead = WeakBindings.bindLong(stats.filesRead());
|
|
|
this.filesWritten = WeakBindings.bindLong(stats.filesWritten());
|
|
|
+ this.filesAccessed = WeakBindings.bindLong(stats.filesAccessed());
|
|
|
+ this.totalFilesAccessed = WeakBindings.bindLong(stats.totalFilesAccessed());
|
|
|
this.bpsEncrypted = WeakBindings.bindLong(stats.bytesPerSecondEncryptedProperty());
|
|
|
this.bpsDecrypted = WeakBindings.bindLong(stats.bytesPerSecondDecryptedProperty());
|
|
|
|
|
|
this.ioAnimation = new Timeline(); //TODO Research better timer
|
|
|
- ioAnimation.getKeyFrames().add(new KeyFrame(Duration.seconds(IO_SAMPLING_INTERVAL), new IoSamplingAnimationHandler(readData, writeData)));
|
|
|
+ ioAnimation.getKeyFrames().add(new KeyFrame(Duration.seconds(IO_SAMPLING_INTERVAL), new IoSamplingAnimationHandler(readData, writeData, accessData)));
|
|
|
ioAnimation.setCycleCount(Animation.INDEFINITE);
|
|
|
ioAnimation.play();
|
|
|
|
|
@@ -89,6 +101,7 @@ public class VaultStatisticsController implements FxController {
|
|
|
public void initialize() {
|
|
|
readChart.getData().addAll(readData);
|
|
|
writeChart.getData().addAll(writeData);
|
|
|
+ accessChart.getData().addAll(accessData);
|
|
|
}
|
|
|
|
|
|
private class IoSamplingAnimationHandler implements EventHandler<ActionEvent> {
|
|
@@ -96,16 +109,21 @@ public class VaultStatisticsController implements FxController {
|
|
|
private long step = IO_SAMPLING_STEPS;
|
|
|
private final Series<Number, Number> decryptedBytesRead;
|
|
|
private final Series<Number, Number> encryptedBytesWrite;
|
|
|
+ private final Series<Number, Number> accessedFiles;
|
|
|
private final long[] maxBuf = new long[IO_SAMPLING_STEPS];
|
|
|
+ private final long[] maxAccessBuf = new long[IO_SAMPLING_STEPS];
|
|
|
|
|
|
- public IoSamplingAnimationHandler(Series<Number, Number> readData, Series<Number, Number> writeData) {
|
|
|
+
|
|
|
+ public IoSamplingAnimationHandler(Series<Number, Number> readData, Series<Number, Number> writeData, Series<Number, Number> accessData) {
|
|
|
this.decryptedBytesRead = readData;
|
|
|
this.encryptedBytesWrite = writeData;
|
|
|
+ this.accessedFiles = accessData;
|
|
|
|
|
|
// initialize data once and change value of data points later:
|
|
|
for (int i = 0; i < IO_SAMPLING_STEPS; i++) {
|
|
|
decryptedBytesRead.getData().add(new Data<>(i, 0));
|
|
|
encryptedBytesWrite.getData().add(new Data<>(i, 0));
|
|
|
+ accessedFiles.getData().add(new Data<>(i, 0));
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -114,17 +132,22 @@ public class VaultStatisticsController implements FxController {
|
|
|
final long currentStep = step++;
|
|
|
final long decBytes = stats.bytesPerSecondReadProperty().get();
|
|
|
final long encBytes = stats.bytesPerSecondWrittenProperty().get();
|
|
|
+ final long accFiles = stats.filesAccessed().get();
|
|
|
|
|
|
maxBuf[(int) currentStep % IO_SAMPLING_STEPS] = Math.max(decBytes, encBytes);
|
|
|
- long allTimeMax = Arrays.stream(maxBuf).max().orElse(0l);
|
|
|
+ long allTimeMax = Arrays.stream(maxBuf).max().orElse(0L);
|
|
|
+ maxAccessBuf[(int) currentStep % IO_SAMPLING_STEPS] = accFiles;
|
|
|
+ long allTimeMaxAccessedFiles = Arrays.stream(maxAccessBuf).max().orElse(0L);
|
|
|
|
|
|
// remove oldest value:
|
|
|
decryptedBytesRead.getData().remove(0);
|
|
|
encryptedBytesWrite.getData().remove(0);
|
|
|
+ accessedFiles.getData().remove(0);
|
|
|
|
|
|
// add latest value:
|
|
|
decryptedBytesRead.getData().add(new Data<>(currentStep, decBytes));
|
|
|
encryptedBytesWrite.getData().add(new Data<>(currentStep, encBytes));
|
|
|
+ accessedFiles.getData().add(new Data<>(currentStep, accFiles));
|
|
|
|
|
|
// adjust ranges:
|
|
|
readChartXAxis.setLowerBound(currentStep - IO_SAMPLING_STEPS * 1.0);
|
|
@@ -133,6 +156,9 @@ public class VaultStatisticsController implements FxController {
|
|
|
writeChartXAxis.setLowerBound(currentStep - IO_SAMPLING_STEPS * 1.0);
|
|
|
writeChartXAxis.setUpperBound(currentStep);
|
|
|
writeChartYAxis.setUpperBound(allTimeMax);
|
|
|
+ accessChartXAxis.setLowerBound(currentStep - IO_SAMPLING_STEPS * 1.0);
|
|
|
+ accessChartXAxis.setUpperBound(currentStep);
|
|
|
+ accessChartYAxis.setUpperBound(allTimeMaxAccessedFiles);
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -207,4 +233,12 @@ public class VaultStatisticsController implements FxController {
|
|
|
public LongBinding filesWrittenProperty() {return filesWritten;}
|
|
|
|
|
|
public long getFilesWritten() {return filesWritten.get();}
|
|
|
+
|
|
|
+ public LongBinding filesAccessedProperty() {return filesAccessed;}
|
|
|
+
|
|
|
+ public long getFilesAccessed() {return filesAccessed.get();}
|
|
|
+
|
|
|
+ public LongBinding totalFilesAccessedProperty() {return totalFilesAccessed;}
|
|
|
+
|
|
|
+ public long getTotalFilesAccessed() {return totalFilesAccessed.get();}
|
|
|
}
|