diff --git a/bukkit/pom.xml b/bukkit/pom.xml index 0f2986bf..f36faa58 100644 --- a/bukkit/pom.xml +++ b/bukkit/pom.xml @@ -101,13 +101,6 @@ 0.0.1-SNAPSHOT provided - - - com.zaxxer - HikariCP - 2.5.1 - provided - org.projectlombok diff --git a/common/pom.xml b/common/pom.xml index aadf8e4d..37979574 100644 --- a/common/pom.xml +++ b/common/pom.xml @@ -50,7 +50,7 @@ com.zaxxer HikariCP - 2.5.1 + 2.6.1 provided diff --git a/common/src/main/java/me/lucko/luckperms/common/dependencies/Dependency.java b/common/src/main/java/me/lucko/luckperms/common/dependencies/Dependency.java index f046fbe1..1004f52b 100644 --- a/common/src/main/java/me/lucko/luckperms/common/dependencies/Dependency.java +++ b/common/src/main/java/me/lucko/luckperms/common/dependencies/Dependency.java @@ -33,7 +33,7 @@ public enum Dependency { POSTGRESQL_DRIVER("https://repo1.maven.org/maven2/org/postgresql/postgresql/9.4.1212/postgresql-9.4.1212.jar", "9.4.1212", "org.postgresql.ds.PGSimpleDataSource"), H2_DRIVER("https://repo1.maven.org/maven2/com/h2database/h2/1.4.193/h2-1.4.193.jar", "1.4.193", "org.h2.Driver"), SQLITE_DRIVER("https://repo1.maven.org/maven2/org/xerial/sqlite-jdbc/3.15.1/sqlite-jdbc-3.15.1.jar", "3.15.1", "org.sqlite.JDBC"), - HIKARI("https://repo1.maven.org/maven2/com/zaxxer/HikariCP/2.5.1/HikariCP-2.5.1.jar", "2.5.1", "com.zaxxer.hikari.HikariDataSource"), + HIKARI("https://repo1.maven.org/maven2/com/zaxxer/HikariCP/2.6.1/HikariCP-2.6.1.jar", "2.6.1", "com.zaxxer.hikari.HikariConfig"), SLF4J_SIMPLE("https://repo1.maven.org/maven2/org/slf4j/slf4j-simple/1.7.9/slf4j-simple-1.7.9.jar", "1.7.9", "org.slf4j.impl.SimpleLoggerFactory"), SLF4J_API("https://repo1.maven.org/maven2/org/slf4j/slf4j-api/1.7.9/slf4j-api-1.7.9.jar", "1.7.9", "org.slf4j.helpers.BasicMarkerFactory"), MONGODB_DRIVER("https://repo1.maven.org/maven2/org/mongodb/mongo-java-driver/3.4.1/mongo-java-driver-3.4.1.jar", "3.4.1", "com.mongodb.Mongo"), diff --git a/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/FlatfileProvider.java b/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/FlatfileProvider.java index b0c60f0a..86457182 100644 --- a/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/FlatfileProvider.java +++ b/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/FlatfileProvider.java @@ -23,6 +23,7 @@ package me.lucko.luckperms.common.storage.backing.sqlprovider; import java.io.File; +import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.util.concurrent.locks.ReentrantLock; @@ -57,18 +58,25 @@ abstract class FlatfileProvider extends SQLProvider { public WrappedConnection getConnection() throws SQLException { lock.lock(); try { - if (connection == null || connection.isClosed()) { + if (this.connection == null || this.connection.isClosed()) { try { Class.forName(getDriverClass()); } catch (ClassNotFoundException ignored) {} - connection = new WrappedConnection(DriverManager.getConnection(getDriverId() + ":" + file.getAbsolutePath()), false); + Connection connection = DriverManager.getConnection(getDriverId() + ":" + file.getAbsolutePath()); + if (connection != null) { + this.connection = new WrappedConnection(connection, false); + } } } finally { lock.unlock(); } - return connection; + if (this.connection == null) { + throw new SQLException("Connection is null"); + } + + return this.connection; } } diff --git a/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/MySQLProvider.java b/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/MySQLProvider.java index de555ad0..091328f5 100644 --- a/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/MySQLProvider.java +++ b/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/MySQLProvider.java @@ -27,6 +27,7 @@ import com.zaxxer.hikari.HikariDataSource; import me.lucko.luckperms.common.storage.DatastoreConfiguration; +import java.sql.Connection; import java.sql.SQLException; import java.util.concurrent.TimeUnit; @@ -62,21 +63,26 @@ public class MySQLProvider extends SQLProvider { config.addDataSourceProperty("databaseName", database); config.addDataSourceProperty("user", username); config.addDataSourceProperty("password", password); - config.addDataSourceProperty("cachePrepStmts", true); - config.addDataSourceProperty("prepStmtCacheSize", 250); - config.addDataSourceProperty("prepStmtCacheSqlLimit", 2048); - config.addDataSourceProperty("useServerPrepStmts", true); - config.addDataSourceProperty("cacheCallableStmts", true); - config.addDataSourceProperty("alwaysSendSetIsolation", false); - config.addDataSourceProperty("cacheServerConfiguration", true); - config.addDataSourceProperty("elideSetAutoCommits", true); - config.addDataSourceProperty("useLocalSessionState", true); + config.addDataSourceProperty("cachePrepStmts", "true"); + config.addDataSourceProperty("prepStmtCacheSize", "250"); + config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048"); + config.addDataSourceProperty("useServerPrepStmts", "true"); + config.addDataSourceProperty("cacheCallableStmts", "true"); + config.addDataSourceProperty("alwaysSendSetIsolation", "false"); + config.addDataSourceProperty("cacheServerConfiguration", "true"); + config.addDataSourceProperty("elideSetAutoCommits", "true"); + config.addDataSourceProperty("useLocalSessionState", "true"); config.addDataSourceProperty("characterEncoding", "utf8"); config.addDataSourceProperty("useUnicode", "true"); - config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10)); // 10000 - config.setLeakDetectionThreshold(TimeUnit.SECONDS.toMillis(5)); // 5000 - config.setValidationTimeout(TimeUnit.SECONDS.toMillis(3)); // 3000 - config.setInitializationFailFast(true); + + // We will wait for 15 seconds to get a connection from the pool. + // Default is 30, but it shouldn't be taking that long. + config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(15)); // 15000 + + // If a connection is not returned within 10 seconds, it's probably safe to assume it's been leaked. + config.setLeakDetectionThreshold(TimeUnit.SECONDS.toMillis(10)); // 10000 + + // The drivers are really old in some of the older Spigot binaries, so Connection#isValid doesn't work. config.setConnectionTestQuery("/* LuckPerms ping */ SELECT 1"); hikari = new HikariDataSource(config); @@ -91,6 +97,10 @@ public class MySQLProvider extends SQLProvider { @Override public WrappedConnection getConnection() throws SQLException { - return new WrappedConnection(hikari.getConnection(), true); + Connection connection = hikari.getConnection(); + if (connection == null) { + throw new SQLException("Connection is null"); + } + return new WrappedConnection(connection, true); } } diff --git a/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/PostgreSQLProvider.java b/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/PostgreSQLProvider.java index feed77c7..2b4ca269 100644 --- a/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/PostgreSQLProvider.java +++ b/common/src/main/java/me/lucko/luckperms/common/storage/backing/sqlprovider/PostgreSQLProvider.java @@ -27,6 +27,7 @@ import com.zaxxer.hikari.HikariDataSource; import me.lucko.luckperms.common.storage.DatastoreConfiguration; +import java.sql.Connection; import java.sql.SQLException; import java.util.concurrent.TimeUnit; @@ -62,10 +63,15 @@ public class PostgreSQLProvider extends SQLProvider { config.addDataSourceProperty("databaseName", database); config.addDataSourceProperty("user", username); config.addDataSourceProperty("password", password); - config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10)); // 10000 - config.setLeakDetectionThreshold(TimeUnit.SECONDS.toMillis(5)); // 5000 - config.setValidationTimeout(TimeUnit.SECONDS.toMillis(3)); // 3000 - config.setInitializationFailFast(true); + + // We will wait for 15 seconds to get a connection from the pool. + // Default is 30, but it shouldn't be taking that long. + config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(15)); // 15000 + + // If a connection is not returned within 10 seconds, it's probably safe to assume it's been leaked. + config.setLeakDetectionThreshold(TimeUnit.SECONDS.toMillis(10)); // 10000 + + // Just in-case the driver isn't JDBC4+ config.setConnectionTestQuery("/* LuckPerms ping */ SELECT 1"); hikari = new HikariDataSource(config); @@ -80,6 +86,10 @@ public class PostgreSQLProvider extends SQLProvider { @Override public WrappedConnection getConnection() throws SQLException { - return new WrappedConnection(hikari.getConnection(), true); + Connection connection = hikari.getConnection(); + if (connection == null) { + throw new SQLException("Connection is null"); + } + return new WrappedConnection(connection, true); } }