在我开始之前,我想说我已经检查过以下内容并且他们没有帮助我:
基本上,我得到了一个HikariCP stracktrace并且我不知道造成它的原因。
java.sql.SQLTransientConnectionException: HikariPool-1 - Connection is not available, request timed out after 30000ms.
at com.zaxxer.hikari.pool.HikariPool.createTimeoutException(HikariPool.java:548)
at com.zaxxer.hikari.pool.HikariPool.getConnection(HikariPool.java:186)
at com.zaxxer.hikari.pool.HikariPool.getConnection(HikariPool.java:145)
at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:83)
at de.arraying.Arraybot.managers.ManagerSync.addCustomCommand(ManagerSync.java:192)
at de.arraying.Arraybot.commands.CommandsCommand.onCommand(CommandsCommand.java:100)
at de.arraying.Arraybot.commands.Command.execute(Command.java:72)
at de.arraying.Arraybot.listeners.ListenerChat.onGuildMessageReceived(ListenerChat.java:68)
at net.dv8tion.jda.core.hooks.ListenerAdapter.onEvent(ListenerAdapter.java:299)
at net.dv8tion.jda.core.hooks.InterfacedEventManager.handle(InterfacedEventManager.java:64)
at net.dv8tion.jda.core.handle.MessageCreateHandler.handleDefaultMessage(MessageCreateHandler.java:97)
at net.dv8tion.jda.core.handle.MessageCreateHandler.handleInternally(MessageCreateHandler.java:47)
at net.dv8tion.jda.core.handle.SocketHandler.handle(SocketHandler.java:38)
at net.dv8tion.jda.core.requests.WebSocketClient.handleEvent(WebSocketClient.java:688)
at net.dv8tion.jda.core.requests.WebSocketClient.onTextMessage(WebSocketClient.java:437)
at com.neovisionaries.ws.client.ListenerManager.callOnTextMessage(ListenerManager.java:352)
at com.neovisionaries.ws.client.ReadingThread.callOnTextMessage(ReadingThread.java:262)
at com.neovisionaries.ws.client.ReadingThread.callOnTextMessage(ReadingThread.java:240)
at com.neovisionaries.ws.client.ReadingThread.handleTextFrame(ReadingThread.java:965)
at com.neovisionaries.ws.client.ReadingThread.handleFrame(ReadingThread.java:748)
at com.neovisionaries.ws.client.ReadingThread.main(ReadingThread.java:110)
at com.neovisionaries.ws.client.ReadingThread.run(ReadingThread.java:66)
我已尝试更改maximum pool size
,minimum idle
,我也启用了leak detection
(2s)。这些都没有帮助,除了我每次执行查询时都会进行泄漏检测,所以可能与此相关。
这是我目前的配置:
HikariConfig hikariConfig = new HikariConfig();
hikariConfig.setJdbcUrl("jdbc:mysql://"+url+":3306/"+database+"?useSSL=false");
hikariConfig.setUsername(username);
hikariConfig.setPassword(password);
hikariConfig.setMaximumPoolSize(10);
hikariConfig.setMinimumIdle(3);
hikariConfig.setLeakDetectionThreshold(2000);
dataSource = new HikariDataSource(hikariConfig);
我的查询方法结构如下:
// inside a try/catch, after some checks that aren't related.
PreparedStatement preparedStatement =
dataSource.getConnection().prepareStatement(query);
preparedStatement.setString(2, id);
preparedStatement.setString(3, name);
preparedStatement.setObject(1, value);
preparedStatement.executeUpdate();
preparedStatement.close();
我应该在此之后关闭连接吗?我可以想象的唯一可能导致错误的是内存泄漏,我不认为我有任何错误。我的CPU使用率也很好,我的互联网连接也是如此。查询都可以正常工作,除了几次开始抛出此错误的事实。
答案 0 :(得分:8)
"我每次执行查询时都会收到泄漏检测"。
你当然是。在您的示例中,您从Connection
中获得DataSource
,执行PreparedStatement
,关闭PreparedStatement
,然后关闭Connection
,所以它没有返回池中导致泄漏。
关闭你的联系人!只有你可以防止事故......错误,连接泄漏。