mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 06:30:46 +01:00
Adjust bStats data sending delay (#4914)
Many servers tend to restart at a fixed time at xx:00 which causes an uneven distribution of requests on the bStats backend. To circumvent this problem, this commit introduces some randomness to the initial and second delay.
This commit is contained in:
parent
57c5f5e566
commit
fdaae06cdf
2 changed files with 30 additions and 20 deletions
|
@ -45,15 +45,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
--- a/src/main/java/com/destroystokyo/paper/Metrics.java
|
--- a/src/main/java/com/destroystokyo/paper/Metrics.java
|
||||||
+++ b/src/main/java/com/destroystokyo/paper/Metrics.java
|
+++ b/src/main/java/com/destroystokyo/paper/Metrics.java
|
||||||
@@ -0,0 +0,0 @@ public class Metrics {
|
@@ -0,0 +0,0 @@ public class Metrics {
|
||||||
timer.scheduleAtFixedRate(new TimerTask() {
|
* Starts the Scheduler which submits our data every 30 minutes.
|
||||||
@Override
|
*/
|
||||||
public void run() {
|
private void startSubmitting() {
|
||||||
+ if (MinecraftServer.getServer().hasStopped()) {
|
- final Runnable submitTask = this::submitData;
|
||||||
+ return;
|
+ final Runnable submitTask = () -> {
|
||||||
+ }
|
+ if (MinecraftServer.getServer().hasStopped()) {
|
||||||
submitData();
|
+ return;
|
||||||
}
|
+ }
|
||||||
}, 1000 * 60 * 5, 1000 * 60 * 30);
|
+ submitData();
|
||||||
|
+ };
|
||||||
|
|
||||||
|
// Many servers tend to restart at a fixed time at xx:00 which causes an uneven distribution of requests on the
|
||||||
|
// bStats backend. To circumvent this problem, we introduce some randomness into the initial and second delay.
|
||||||
diff --git a/src/main/java/net/minecraft/server/CrashReport.java b/src/main/java/net/minecraft/server/CrashReport.java
|
diff --git a/src/main/java/net/minecraft/server/CrashReport.java b/src/main/java/net/minecraft/server/CrashReport.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/CrashReport.java
|
--- a/src/main/java/net/minecraft/server/CrashReport.java
|
||||||
|
|
|
@ -24,7 +24,6 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import net.minecraft.server.MinecraftServer;
|
+import net.minecraft.server.MinecraftServer;
|
||||||
+import org.bukkit.Bukkit;
|
+import org.bukkit.Bukkit;
|
||||||
+import org.bukkit.configuration.file.YamlConfiguration;
|
+import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
+import org.bukkit.craftbukkit.util.CraftLegacy;
|
|
||||||
+import org.bukkit.craftbukkit.util.CraftMagicNumbers;
|
+import org.bukkit.craftbukkit.util.CraftMagicNumbers;
|
||||||
+import org.bukkit.plugin.Plugin;
|
+import org.bukkit.plugin.Plugin;
|
||||||
+
|
+
|
||||||
|
@ -39,6 +38,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+import java.net.URL;
|
+import java.net.URL;
|
||||||
+import java.util.*;
|
+import java.util.*;
|
||||||
+import java.util.concurrent.Callable;
|
+import java.util.concurrent.Callable;
|
||||||
|
+import java.util.concurrent.Executors;
|
||||||
|
+import java.util.concurrent.ScheduledExecutorService;
|
||||||
|
+import java.util.concurrent.TimeUnit;
|
||||||
+import java.util.logging.Level;
|
+import java.util.logging.Level;
|
||||||
+import java.util.logging.Logger;
|
+import java.util.logging.Logger;
|
||||||
+import java.util.regex.Matcher;
|
+import java.util.regex.Matcher;
|
||||||
|
@ -52,6 +54,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ */
|
+ */
|
||||||
+public class Metrics {
|
+public class Metrics {
|
||||||
+
|
+
|
||||||
|
+ // Executor service for requests
|
||||||
|
+ // We use an executor service because the Bukkit scheduler is affected by server lags
|
||||||
|
+ private final ScheduledExecutorService scheduler = Executors.newScheduledThreadPool(1);
|
||||||
|
+
|
||||||
+ // The version of this bStats class
|
+ // The version of this bStats class
|
||||||
+ public static final int B_STATS_VERSION = 1;
|
+ public static final int B_STATS_VERSION = 1;
|
||||||
+
|
+
|
||||||
|
@ -107,16 +113,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ * Starts the Scheduler which submits our data every 30 minutes.
|
+ * Starts the Scheduler which submits our data every 30 minutes.
|
||||||
+ */
|
+ */
|
||||||
+ private void startSubmitting() {
|
+ private void startSubmitting() {
|
||||||
+ final Timer timer = new Timer(true);
|
+ final Runnable submitTask = this::submitData;
|
||||||
+ timer.scheduleAtFixedRate(new TimerTask() {
|
+
|
||||||
+ @Override
|
+ // Many servers tend to restart at a fixed time at xx:00 which causes an uneven distribution of requests on the
|
||||||
+ public void run() {
|
+ // bStats backend. To circumvent this problem, we introduce some randomness into the initial and second delay.
|
||||||
+ submitData();
|
+ // WARNING: You must not modify any part of this Metrics class, including the submit delay or frequency!
|
||||||
+ }
|
+ // WARNING: Modifying this code will get your plugin banned on bStats. Just don't do it!
|
||||||
+ }, 1000 * 60 * 5, 1000 * 60 * 30);
|
+ long initialDelay = (long) (1000 * 60 * (3 + Math.random() * 3));
|
||||||
+ // Submit the data every 30 minutes, first time after 5 minutes to give other plugins enough time to start
|
+ long secondDelay = (long) (1000 * 60 * (Math.random() * 30));
|
||||||
+ // WARNING: Changing the frequency has no effect but your plugin WILL be blocked/deleted!
|
+ scheduler.schedule(submitTask, initialDelay, TimeUnit.MILLISECONDS);
|
||||||
+ // WARNING: Just don't do it!
|
+ scheduler.scheduleAtFixedRate(submitTask, initialDelay + secondDelay, 1000 * 60 * 30, TimeUnit.MILLISECONDS);
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ /**
|
+ /**
|
||||||
|
|
Loading…
Reference in a new issue