diff options
Diffstat (limited to 'patches/server/0063-Chunk-Save-Reattempt.patch')
-rw-r--r-- | patches/server/0063-Chunk-Save-Reattempt.patch | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/patches/server/0063-Chunk-Save-Reattempt.patch b/patches/server/0063-Chunk-Save-Reattempt.patch new file mode 100644 index 0000000000..66fe0ef951 --- /dev/null +++ b/patches/server/0063-Chunk-Save-Reattempt.patch @@ -0,0 +1,51 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Aikar <[email protected]> +Date: Mon, 4 Mar 2013 23:46:10 -0500 +Subject: [PATCH] Chunk Save Reattempt + +We commonly have "Stream Closed" errors on chunk saving, so this code should re-try to save the chunk in the event of failure and hopefully prevent rollbacks. + +diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java +index 8adebb8408cc22ae7e9e89721645e5dd27a41cd8..038e2177182c94baa4af24f9111cf155ec342dfe 100644 +--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java ++++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java +@@ -275,7 +275,7 @@ public class RegionFile implements AutoCloseable { + return true; + } + } catch (IOException ioexception) { +- com.destroystokyo.paper.exception.ServerInternalException.reportInternalException(ioexception); // Paper ++ com.destroystokyo.paper.util.SneakyThrow.sneaky(ioexception); // Paper - we want the upper try/catch to retry this + return false; + } + } +diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java +index 45cec71b3b2f9444d7be7e5bf9fab166b28ea34d..ece0fd4b51d124be232e24d08f115b9267cb21cb 100644 +--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java ++++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java +@@ -167,6 +167,7 @@ public class RegionFileStorage implements AutoCloseable { + } + // Paper end - rewrite chunk system + try { // Paper ++ int attempts = 0; Exception laste = null; while (attempts++ < 5) { try { // Paper + + if (nbt == null) { + regionfile.clear(pos); +@@ -191,7 +192,18 @@ public class RegionFileStorage implements AutoCloseable { + dataoutputstream.close(); + } + } ++ // Paper start ++ return; ++ } catch (Exception ex) { ++ laste = ex; ++ } ++ } + ++ if (laste != null) { ++ com.destroystokyo.paper.exception.ServerInternalException.reportInternalException(laste); ++ net.minecraft.server.MinecraftServer.LOGGER.error("Failed to save chunk " + pos, laste); ++ } ++ // Paper end + } finally { // Paper start + regionfile.fileLock.unlock(); + } // Paper end |