2020-04-27 07:34:45 +00:00
|
|
|
From 88d409e97c231e0d2feddd4422df304165e39083 Mon Sep 17 00:00:00 2001
|
2018-07-17 14:44:32 +00:00
|
|
|
From: Minecrell <minecrell@minecrell.net>
|
|
|
|
Date: Tue, 17 Jul 2018 16:42:17 +0200
|
|
|
|
Subject: [PATCH] Use asynchronous Log4j 2 loggers
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/pom.xml b/pom.xml
|
2020-04-27 07:34:45 +00:00
|
|
|
index 6fe4eff84b..fd417a9eeb 100644
|
2018-07-17 14:44:32 +00:00
|
|
|
--- a/pom.xml
|
|
|
|
+++ b/pom.xml
|
2020-04-27 07:34:45 +00:00
|
|
|
@@ -77,6 +77,13 @@
|
2018-08-26 18:11:49 +00:00
|
|
|
<artifactId>log4j-iostreams</artifactId>
|
2018-07-17 14:44:32 +00:00
|
|
|
<version>2.8.1</version>
|
|
|
|
</dependency>
|
|
|
|
+ <!-- Paper - Async loggers -->
|
|
|
|
+ <dependency>
|
|
|
|
+ <groupId>com.lmax</groupId>
|
|
|
|
+ <artifactId>disruptor</artifactId>
|
|
|
|
+ <version>3.4.2</version>
|
|
|
|
+ <scope>runtime</scope>
|
|
|
|
+ </dependency>
|
|
|
|
<dependency>
|
2018-08-26 18:11:49 +00:00
|
|
|
<groupId>org.ow2.asm</groupId>
|
|
|
|
<artifactId>asm</artifactId>
|
2019-06-29 17:04:38 +00:00
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/log/LogFullPolicy.java b/src/main/java/com/destroystokyo/paper/log/LogFullPolicy.java
|
|
|
|
new file mode 100644
|
2020-04-27 05:37:37 +00:00
|
|
|
index 0000000000..db652a1f7a
|
2019-06-29 17:04:38 +00:00
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/log/LogFullPolicy.java
|
|
|
|
@@ -0,0 +1,17 @@
|
|
|
|
+package com.destroystokyo.paper.log;
|
|
|
|
+
|
|
|
|
+import org.apache.logging.log4j.Level;
|
|
|
|
+import org.apache.logging.log4j.core.async.AsyncQueueFullPolicy;
|
|
|
|
+import org.apache.logging.log4j.core.async.EventRoute;
|
|
|
|
+
|
|
|
|
+public final class LogFullPolicy implements AsyncQueueFullPolicy {
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * Prevents log calls being logged out of order when the log queue is full.
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public EventRoute getRoute(final long backgroundThreadId, final Level level) {
|
|
|
|
+ return EventRoute.ENQUEUE;
|
|
|
|
+ }
|
|
|
|
+}
|
2018-07-17 14:44:32 +00:00
|
|
|
diff --git a/src/main/resources/log4j2.component.properties b/src/main/resources/log4j2.component.properties
|
2020-04-27 05:37:37 +00:00
|
|
|
index 0694b21465..30efeb5faf 100644
|
2019-07-24 00:25:05 +00:00
|
|
|
--- a/src/main/resources/log4j2.component.properties
|
2018-07-17 14:44:32 +00:00
|
|
|
+++ b/src/main/resources/log4j2.component.properties
|
2019-07-24 00:25:05 +00:00
|
|
|
@@ -1 +1,3 @@
|
2018-07-17 14:44:32 +00:00
|
|
|
+Log4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector
|
2019-07-02 04:51:06 +00:00
|
|
|
+log4j2.AsyncQueueFullPolicy="com.destroystokyo.paper.log.LogFullPolicy"
|
2019-07-24 00:25:05 +00:00
|
|
|
log4j.skipJansi=true
|
2018-07-17 14:44:32 +00:00
|
|
|
--
|
2020-04-27 05:37:37 +00:00
|
|
|
2.26.2
|
2018-07-17 14:44:32 +00:00
|
|
|
|