Hacky fix to forge crash

The server crashes due to sqlite driver loading disabling class loading caches.
This re-enables them after using the method.

Note that if a class is loaded in a small timeframe between sqlite driver loading and
the finally-block running there is a slight chance of a crash, but it is less than 100%

Affects issues:
- Fix #2202
This commit is contained in:
Risto Lahtela 2022-02-01 20:42:45 +02:00
parent 1ddd8f4099
commit 922c99872c

View File

@ -37,6 +37,7 @@ import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.Constructor; import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException; import java.lang.reflect.InvocationTargetException;
import java.net.URLConnection;
import java.sql.Connection; import java.sql.Connection;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.List; import java.util.List;
@ -82,7 +83,7 @@ public class SQLiteDB extends SQLDB {
try { try {
return files.getResourceFromJar("dependencies/sqliteDriver.txt").asLines(); return files.getResourceFromJar("dependencies/sqliteDriver.txt").asLines();
} catch (IOException e) { } catch (IOException e) {
throw new RuntimeException("Failed to get SQLite dependency information", e); throw new DBInitException("Failed to get SQLite dependency information: " + e.getMessage(), e);
} }
} }
@ -93,7 +94,7 @@ public class SQLiteDB extends SQLDB {
connection = getNewConnection(databaseFile); connection = getNewConnection(databaseFile);
} catch (SQLException e) { } catch (SQLException e) {
throw new DBInitException(e.getMessage(), e); throw new DBInitException(e.toString(), e);
} }
startConnectionPingTask(); startConnectionPingTask();
} }
@ -147,6 +148,16 @@ public class SQLiteDB extends SQLDB {
return tryToConnect(dbFilePath, false); return tryToConnect(dbFilePath, false);
} catch (InstantiationException | IllegalAccessException e) { } catch (InstantiationException | IllegalAccessException e) {
throw new DBInitException("Failed to initialize SQLite Driver", e); throw new DBInitException("Failed to initialize SQLite Driver", e);
} finally {
new URLConnection(null) {
@Override
public void connect() {
// Hack for fixing a class loading crash (https://github.com/plan-player-analytics/Plan/issues/2202)
// Caused by https://github.com/xerial/sqlite-jdbc/issues/656
// Where setDefaultUseCaches is set to false
// TODO Remove after the underlying issue has been fixed in SQLite
}
}.setDefaultUseCaches(true);
} }
} }