From 75618c5da8822bd7aebdff547cf98b60476c6920 Mon Sep 17 00:00:00 2001 From: Brokkonaut Date: Wed, 8 Feb 2017 15:11:43 -0600 Subject: [PATCH] Make chunk unload targetSize more aggressive Re: GH-597 --- ...-Spigot-chunk-unload-rate-throttling.patch | 37 ------------------- ...more-aggressive-in-the-chunk-unload-.patch | 20 ++++++++++ 2 files changed, 20 insertions(+), 37 deletions(-) delete mode 100644 Spigot-Server-Patches/Disable-Spigot-chunk-unload-rate-throttling.patch create mode 100644 Spigot-Server-Patches/Make-targetSize-more-aggressive-in-the-chunk-unload-.patch diff --git a/Spigot-Server-Patches/Disable-Spigot-chunk-unload-rate-throttling.patch b/Spigot-Server-Patches/Disable-Spigot-chunk-unload-rate-throttling.patch deleted file mode 100644 index 08bc6fa501..0000000000 --- a/Spigot-Server-Patches/Disable-Spigot-chunk-unload-rate-throttling.patch +++ /dev/null @@ -1,37 +0,0 @@ -From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 -From: Zach Brown <1254957+zachbr@users.noreply.github.com> -Date: Tue, 7 Feb 2017 16:55:35 -0600 -Subject: [PATCH] Disable Spigot chunk unload rate throttling - - -diff --git a/src/main/java/net/minecraft/server/ChunkProviderServer.java b/src/main/java/net/minecraft/server/ChunkProviderServer.java -index 7006466b5..695c9bd2a 100644 ---- a/src/main/java/net/minecraft/server/ChunkProviderServer.java -+++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java -@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider { - if (!this.unloadQueue.isEmpty()) { - // Spigot start - org.spigotmc.SlackActivityAccountant activityAccountant = this.world.getMinecraftServer().slackActivityAccountant; -- activityAccountant.startActivity(0.5); -+ //activityAccountant.startActivity(0.5); // Paper - int targetSize = (int) (this.unloadQueue.size() * UNLOAD_QUEUE_RESIZE_FACTOR); - // Spigot end - -@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider { - // CraftBukkit end - - // Spigot start -- if (this.unloadQueue.size() <= targetSize && activityAccountant.activityTimeIsExhausted()) { -+ if (false && this.unloadQueue.size() <= targetSize && activityAccountant.activityTimeIsExhausted()) { // Paper - Disable for the time being - break; - } - // Spigot end - } - } - -- activityAccountant.endActivity(); // Spigot -+ //activityAccountant.endActivity(); // Spigot // Paper - } - // Paper start - delayed chunk unloads - long now = System.currentTimeMillis(); --- \ No newline at end of file diff --git a/Spigot-Server-Patches/Make-targetSize-more-aggressive-in-the-chunk-unload-.patch b/Spigot-Server-Patches/Make-targetSize-more-aggressive-in-the-chunk-unload-.patch new file mode 100644 index 0000000000..4c6f5c7859 --- /dev/null +++ b/Spigot-Server-Patches/Make-targetSize-more-aggressive-in-the-chunk-unload-.patch @@ -0,0 +1,20 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Brokkonaut +Date: Tue, 7 Feb 2017 16:55:35 -0600 +Subject: [PATCH] Make targetSize more aggressive in the chunk unload queue + + +diff --git a/src/main/java/net/minecraft/server/ChunkProviderServer.java b/src/main/java/net/minecraft/server/ChunkProviderServer.java +index 7006466b5..c32fb3ef5 100644 +--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java ++++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java +@@ -0,0 +0,0 @@ public class ChunkProviderServer implements IChunkProvider { + // Spigot start + org.spigotmc.SlackActivityAccountant activityAccountant = this.world.getMinecraftServer().slackActivityAccountant; + activityAccountant.startActivity(0.5); +- int targetSize = (int) (this.unloadQueue.size() * UNLOAD_QUEUE_RESIZE_FACTOR); ++ int targetSize = Math.min(this.unloadQueue.size() - 100, (int) (this.unloadQueue.size() * UNLOAD_QUEUE_RESIZE_FACTOR)); // Paper - Make more aggressive + // Spigot end + + Iterator iterator = this.unloadQueue.iterator(); +-- \ No newline at end of file