geforkt von Mirrors/Paper
Use at minimum 2 threads for Data fixers
Per MC-138093 comments, ForkJoinPool uses unlimited threads if parallelism is ever 1. A 2 core machine will end up with 1 with the change I had previously made, so bumped the min to 2 so we will never trigger the unlimited thread situation. This aligns the min back with Spigot, but allows use of more threads on systems with more cores.
Dieser Commit ist enthalten in:
Ursprung
e76d475d7f
Commit
58692e12eb
@ -13,7 +13,7 @@ index 7ac07ac07ac0..7ac07ac07ac0 100644
|
||||
a(datafixerbuilder);
|
||||
// CraftBukkit start
|
||||
- ForkJoinPool pool = new ForkJoinPool(Integer.getInteger("net.minecraft.server.DataConverterRegistry.bootstrapThreads", Math.min(Runtime.getRuntime().availableProcessors(), 2)));
|
||||
+ ForkJoinPool pool = new ForkJoinPool(Integer.getInteger("net.minecraft.server.DataConverterRegistry.bootstrapThreads", Math.min(6, Math.max(Runtime.getRuntime().availableProcessors() - 2, 1)))); // Paper - use more reasonable default
|
||||
+ ForkJoinPool pool = new ForkJoinPool(Integer.getInteger("net.minecraft.server.DataConverterRegistry.bootstrapThreads", Math.min(6, Math.max(Runtime.getRuntime().availableProcessors() - 2, 2)))); // Paper - use more reasonable default - 2 is hard minimum to avoid using unlimited threads
|
||||
DataFixer fixer = datafixerbuilder.build(pool);
|
||||
pool.shutdown();
|
||||
return fixer;
|
||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren