2019-04-22 22:36:14 +01:00
|
|
|
From 8efbb3a0533a16d6c9e3ac27e41cd03bba1e35d8 Mon Sep 17 00:00:00 2001
|
2018-08-26 14:11:49 -04:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Fri, 4 Nov 2016 02:12:10 -0400
|
|
|
|
Subject: [PATCH] Chunk Save Stats Debug Option
|
|
|
|
|
|
|
|
Adds a command line flag to enable stats on how chunk saves are processing.
|
|
|
|
|
|
|
|
Stats on current queue, how many was processed and how many were queued.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkProviderServer.java b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
2019-04-22 22:36:14 +01:00
|
|
|
index 9b5908a5b4..2997767282 100644
|
2018-08-26 14:11:49 -04:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
2019-01-01 03:15:55 +00:00
|
|
|
@@ -28,6 +28,11 @@ public class ChunkProviderServer implements IChunkProvider {
|
2018-08-26 14:11:49 -04:00
|
|
|
public final LongSet unloadQueue = new LongOpenHashSet();
|
|
|
|
public final ChunkGenerator<?> chunkGenerator;
|
2018-10-23 00:16:21 +01:00
|
|
|
public final IChunkLoader chunkLoader;
|
2018-08-26 14:11:49 -04:00
|
|
|
+ // Paper start - chunk save stats
|
|
|
|
+ private long lastQueuedSaves = 0L; // Paper
|
|
|
|
+ private long lastProcessedSaves = 0L; // Paper
|
|
|
|
+ private long lastSaveStatPrinted = System.currentTimeMillis();
|
|
|
|
+ // Paper end
|
|
|
|
public final Long2ObjectMap<Chunk> chunks = Long2ObjectMaps.synchronize(new ChunkMap(8192));
|
|
|
|
private Chunk lastChunk;
|
|
|
|
private final ChunkTaskScheduler chunkScheduler;
|
2019-01-04 19:19:36 +00:00
|
|
|
@@ -239,6 +244,29 @@ public class ChunkProviderServer implements IChunkProvider {
|
2018-08-26 14:11:49 -04:00
|
|
|
// Paper start
|
2018-12-17 05:18:06 +00:00
|
|
|
final ChunkRegionLoader chunkLoader = (ChunkRegionLoader) world.getChunkProvider().chunkLoader;
|
2018-08-26 14:11:49 -04:00
|
|
|
final int queueSize = chunkLoader.getQueueSize();
|
|
|
|
+
|
|
|
|
+ final long now = System.currentTimeMillis();
|
|
|
|
+ final long timeSince = (now - lastSaveStatPrinted) / 1000;
|
|
|
|
+ final Integer printRateSecs = Integer.getInteger("printSaveStats");
|
|
|
|
+ if (printRateSecs != null && timeSince >= printRateSecs) {
|
|
|
|
+ final String timeStr = "/" + timeSince +"s";
|
|
|
|
+ final long queuedSaves = chunkLoader.getQueuedSaves();
|
|
|
|
+ long queuedDiff = queuedSaves - lastQueuedSaves;
|
|
|
|
+ lastQueuedSaves = queuedSaves;
|
|
|
|
+
|
|
|
|
+ final long processedSaves = chunkLoader.getProcessedSaves();
|
|
|
|
+ long processedDiff = processedSaves - lastProcessedSaves;
|
|
|
|
+ lastProcessedSaves = processedSaves;
|
|
|
|
+
|
|
|
|
+ lastSaveStatPrinted = now;
|
|
|
|
+ if (processedDiff > 0 || queueSize > 0 || queuedDiff > 0) {
|
|
|
|
+ System.out.println("[Chunk Save Stats] " + world.worldData.getName() +
|
|
|
|
+ " - Current: " + queueSize +
|
|
|
|
+ " - Queued: " + queuedDiff + timeStr +
|
|
|
|
+ " - Processed: " +processedDiff + timeStr
|
|
|
|
+ );
|
|
|
|
+ }
|
|
|
|
+ }
|
2018-10-05 17:23:20 +02:00
|
|
|
if (!flag && queueSize > world.paperConfig.queueSizeAutoSaveThreshold){
|
2018-08-26 14:11:49 -04:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkRegionLoader.java b/src/main/java/net/minecraft/server/ChunkRegionLoader.java
|
2019-04-22 22:36:14 +01:00
|
|
|
index adfb5d056f..0fc4d9f520 100644
|
2018-08-26 14:11:49 -04:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkRegionLoader.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkRegionLoader.java
|
2019-01-04 19:19:36 +00:00
|
|
|
@@ -156,7 +156,13 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver {
|
2018-08-26 14:11:49 -04:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
- public int getQueueSize() { return queue.size(); } // Paper
|
|
|
|
+ // Paper start
|
|
|
|
+ private long queuedSaves = 0;
|
|
|
|
+ private final java.util.concurrent.atomic.AtomicLong processedSaves = new java.util.concurrent.atomic.AtomicLong(0L);
|
|
|
|
+ public int getQueueSize() { return queue.size(); }
|
|
|
|
+ public long getQueuedSaves() { return queuedSaves; }
|
|
|
|
+ public long getProcessedSaves() { return processedSaves.longValue(); }
|
|
|
|
+ // Paper end
|
|
|
|
|
|
|
|
// CraftBukkit start - Add async variant, provide compatibility
|
|
|
|
@Nullable
|
2019-01-04 19:19:36 +00:00
|
|
|
@@ -348,6 +354,7 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver {
|
2018-08-26 14:11:49 -04:00
|
|
|
protected void a(ChunkCoordIntPair chunkcoordintpair, Supplier<NBTTagCompound> nbttagcompound) { // Spigot
|
2018-09-10 22:38:42 -04:00
|
|
|
this.saveMap.put(chunkcoordintpair.asLong(), nbttagcompound); // Paper
|
|
|
|
queue.add(new QueuedChunk(chunkcoordintpair, nbttagcompound)); // Paper - Chunk queue improvements
|
2018-08-26 14:11:49 -04:00
|
|
|
+ queuedSaves++; // Paper
|
2018-09-10 22:38:42 -04:00
|
|
|
FileIOThread.a().a(this);
|
|
|
|
}
|
|
|
|
|
2019-01-04 19:19:36 +00:00
|
|
|
@@ -375,6 +382,7 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver {
|
2018-09-09 15:29:22 -04:00
|
|
|
// Paper end
|
2018-08-26 14:11:49 -04:00
|
|
|
ChunkCoordIntPair chunkcoordintpair = chunk.coords; // Paper - Chunk queue improvements
|
|
|
|
Supplier<NBTTagCompound> nbttagcompound = chunk.compoundSupplier; // Spigot // Paper
|
|
|
|
+ processedSaves.incrementAndGet(); // Paper
|
|
|
|
|
|
|
|
if (nbttagcompound == null) {
|
|
|
|
return true;
|
|
|
|
--
|
2019-04-22 22:36:14 +01:00
|
|
|
2.21.0
|
2018-08-26 14:11:49 -04:00
|
|
|
|