光驱动程序不支持获取/设置连接的网络超时.(com.mysql.jdbc.JDBC4Connection.getNetw



我在创建Hikari连接时遇到错误,过去使用mysql连接器,但最终我决定使用hikaricp。

这是错误:

[04:17:49] [Server thread/INFO]: HikariPool-1 - Starting...
[04:17:49] [Server thread/INFO]: HikariPool-1 - Driver does not support get/set network timeout for connections. (com.mysql.jdbc.JDBC4Connection.getNetworkTimeout()I)
[04:17:49] [Server thread/INFO]: HikariPool-1 - Start completed.

我的职能:

private static final HikariConfig config;
private HikariDataSource dataSource;
static {
config = new HikariConfig();
}
public void open(){ 
config.setJdbcUrl("jdbc:mysql://localhost:3306/"+ database);
config.setUsername(user);
config.setPassword(password);
config.addDataSourceProperty("cachePrepStmts", "true");
config.addDataSourceProperty("prepStmtCacheSize", "250");
config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");
dataSource = new HikariDataSource(config);
}

我有这个绒球.xml:

<dependencies>
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>3.4.5</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>net.divecrafts</groupId>
<artifactId>spigot</artifactId>
<version>1.8.8</version>
</dependency>
</dependencies>

我的专用服务器是使用 mariadb 的 debian 9(最新版本(

在我看来,这看起来像是版本不匹配的问题。该setNetworkTimeout()JDBC 4.1年推出,在JDBC 4.0中不存在。从堆栈跟踪中可以看出:

(com.mysql.jdbc.JDBC4Connection.getNetworkTimeout()

这就是导致问题的原因。因此,我建议将mysql驱动程序和任何相关的依赖项更新到最新版本,这应该可以解决您的连接问题。

我修复了修改函数的问题:

private Connection connection;
public void open(){
if (checkConnection()) return connection;
final HikariDataSource ds = new HikariDataSource();
ds.setMaximumPoolSize(20);
ds.setDriverClassName("org.mariadb.jdbc.Driver");
ds.setJdbcUrl(String.format("jdbc:mariadb://%s:%s/%s", hostname, port, database));
ds.addDataSourceProperty("user", user);
ds.addDataSourceProperty("password", password);
connection = ds.getConnection();
return connection;
}

我的绒球呢.xml

<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.20</version>
</dependency>
<dependency>
<groupId>org.mariadb.jdbc</groupId>
<artifactId>mariadb-java-client</artifactId>
<version>2.6.0</version>
</dependency>
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>3.4.5</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>net.divecrafts</groupId>
<artifactId>spigot</artifactId>
<version>1.8.8</version>
</dependency>
</dependencies>

总之,由于我使用mariadb,我添加了mariadb连接器。

相关内容

最新更新