aboutsummaryrefslogtreecommitdiff
path: root/spark-common/src/main/java/me/lucko/spark
diff options
context:
space:
mode:
authorLuck <git@lucko.me>2020-01-11 19:24:30 +0000
committerLuck <git@lucko.me>2020-01-11 19:24:30 +0000
commit9e066d1052643b2be270b4039a102260abb41ebb (patch)
tree31bddf86d03d723f4ccdcdcccb67ca9711bb8b5c /spark-common/src/main/java/me/lucko/spark
parent47c65e9c64ec387f845eac5784d86d9685d8ea71 (diff)
downloadspark-9e066d1052643b2be270b4039a102260abb41ebb.tar.gz
spark-9e066d1052643b2be270b4039a102260abb41ebb.tar.bz2
spark-9e066d1052643b2be270b4039a102260abb41ebb.zip
Implement PaperTickCounter using server tick event instead of scheduler
Diffstat (limited to 'spark-common/src/main/java/me/lucko/spark')
-rw-r--r--spark-common/src/main/java/me/lucko/spark/common/monitor/tick/TpsCalculator.java14
1 files changed, 7 insertions, 7 deletions
diff --git a/spark-common/src/main/java/me/lucko/spark/common/monitor/tick/TpsCalculator.java b/spark-common/src/main/java/me/lucko/spark/common/monitor/tick/TpsCalculator.java
index 3000523..6b4f2d1 100644
--- a/spark-common/src/main/java/me/lucko/spark/common/monitor/tick/TpsCalculator.java
+++ b/spark-common/src/main/java/me/lucko/spark/common/monitor/tick/TpsCalculator.java
@@ -42,7 +42,7 @@ public class TpsCalculator implements TickCounter.TickTask {
private static final long SEC_IN_NANO = TimeUnit.SECONDS.toNanos(1);
private static final int TPS = 20;
private static final int SAMPLE_INTERVAL = 20;
- private static final BigDecimal TPS_BASE = new BigDecimal(SEC_IN_NANO).multiply(new BigDecimal((long) SAMPLE_INTERVAL));
+ private static final BigDecimal TPS_BASE = new BigDecimal(SEC_IN_NANO).multiply(new BigDecimal(SAMPLE_INTERVAL));
private final TpsRollingAverage avg5Sec = new TpsRollingAverage(5);
private final TpsRollingAverage avg10Sec = new TpsRollingAverage(10);
@@ -56,7 +56,6 @@ public class TpsCalculator implements TickCounter.TickTask {
private long last = 0;
- // called every tick
@Override
public void onTick(TickCounter counter) {
if (counter.getCurrentTick() % SAMPLE_INTERVAL != 0) {
@@ -72,9 +71,10 @@ public class TpsCalculator implements TickCounter.TickTask {
long diff = now - this.last;
BigDecimal currentTps = TPS_BASE.divide(new BigDecimal(diff), 30, RoundingMode.HALF_UP);
+ BigDecimal total = currentTps.multiply(new BigDecimal(diff));
for (TpsRollingAverage rollingAverage : this.averages) {
- rollingAverage.add(currentTps, diff);
+ rollingAverage.add(currentTps, diff, total);
}
this.last = now;
@@ -120,22 +120,22 @@ public class TpsCalculator implements TickCounter.TickTask {
TpsRollingAverage(int size) {
this.size = size;
this.time = size * SEC_IN_NANO;
- this.total = new BigDecimal((long) TPS).multiply(new BigDecimal(SEC_IN_NANO)).multiply(new BigDecimal((long) size));
+ this.total = new BigDecimal(TPS).multiply(new BigDecimal(SEC_IN_NANO)).multiply(new BigDecimal(size));
this.samples = new BigDecimal[size];
this.times = new long[size];
for (int i = 0; i < size; i++) {
- this.samples[i] = new BigDecimal((long) TPS);
+ this.samples[i] = new BigDecimal(TPS);
this.times[i] = SEC_IN_NANO;
}
}
- public void add(BigDecimal x, long t) {
+ public void add(BigDecimal x, long t, BigDecimal total) {
this.time -= this.times[this.index];
this.total = this.total.subtract(this.samples[this.index].multiply(new BigDecimal(this.times[this.index])));
this.samples[this.index] = x;
this.times[this.index] = t;
this.time += t;
- this.total = this.total.add(x.multiply(new BigDecimal(t)));
+ this.total = this.total.add(total);
if (++this.index == this.size) {
this.index = 0;
}