From c0aeab4cf90bc8157e34939d933e1b300ae4f406 Mon Sep 17 00:00:00 2001 From: Aikar Date: Fri, 4 Nov 2016 02:21:33 -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. --- .../0181-Chunk-Save-Stats-Debug-Option.patch | 94 +++++++++++++++++++ 1 file changed, 94 insertions(+) create mode 100644 Spigot-Server-Patches/0181-Chunk-Save-Stats-Debug-Option.patch diff --git a/Spigot-Server-Patches/0181-Chunk-Save-Stats-Debug-Option.patch b/Spigot-Server-Patches/0181-Chunk-Save-Stats-Debug-Option.patch new file mode 100644 index 0000000000..53f2448423 --- /dev/null +++ b/Spigot-Server-Patches/0181-Chunk-Save-Stats-Debug-Option.patch @@ -0,0 +1,94 @@ +From 80c6641efa6b60e138ba25d9cdd9fdce9a45a902 Mon Sep 17 00:00:00 2001 +From: Aikar +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 +index 99afdb7..3a44ad3 100644 +--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java ++++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java +@@ -27,6 +27,11 @@ public class ChunkProviderServer implements IChunkProvider { + public final it.unimi.dsi.fastutil.longs.LongSet unloadQueue = new it.unimi.dsi.fastutil.longs.LongArraySet(); // PAIL: private -> public // Paper + public final ChunkGenerator chunkGenerator; + private final IChunkLoader chunkLoader; ++ // Paper start - chunk save stats ++ private long lastQueuedSaves = 0L; // Paper ++ private long lastProcessedSaves = 0L; // Paper ++ private long lastSaveStatPrinted = System.currentTimeMillis(); ++ // Paper end + // Paper start + protected Chunk lastChunkByPos = null; + public Long2ObjectOpenHashMap chunks = new Long2ObjectOpenHashMap(8192) { +@@ -256,6 +261,30 @@ public class ChunkProviderServer implements IChunkProvider { + // Paper start + final ChunkRegionLoader chunkLoader = (ChunkRegionLoader) world.getChunkProviderServer().chunkLoader; + 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 ++ ); ++ } ++ } ++ + if (queueSize > world.paperConfig.queueSizeAutoSaveThreshold){ + return false; + } +diff --git a/src/main/java/net/minecraft/server/ChunkRegionLoader.java b/src/main/java/net/minecraft/server/ChunkRegionLoader.java +index 70e71cc..08f6f0d 100644 +--- a/src/main/java/net/minecraft/server/ChunkRegionLoader.java ++++ b/src/main/java/net/minecraft/server/ChunkRegionLoader.java +@@ -33,7 +33,13 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver { + } + + // CraftBukkit start +- 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 + public boolean chunkExists(World world, int i, int j) { + ChunkCoordIntPair chunkcoordintpair = new ChunkCoordIntPair(i, j); + +@@ -150,6 +156,7 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver { + synchronized (lock) { // Paper - Chunk queue improvements + this.b.put(chunkcoordintpair, nbttagcompound); + } ++ queuedSaves++; // Paper + queue.add(new QueuedChunk(chunkcoordintpair, nbttagcompound)); // Paper - Chunk queue improvements + + FileIOThread.a().a(this); +@@ -167,6 +174,7 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver { + return false; + } else { + ChunkCoordIntPair chunkcoordintpair = chunk.coords; // Paper - Chunk queue improvements ++ processedSaves.incrementAndGet(); // Paper + + boolean flag; + +-- +2.10.2 +