Skip to content

Commit

Permalink
Add a timeout for the backend stats collection query
Browse files Browse the repository at this point in the history
Default the stats collection query to use EXECUTE IMMEDIATE by default,
with the option to use explicit PREPARE if desired
  • Loading branch information
willmostly committed Jan 14, 2025
1 parent 8893975 commit 0b8a88b
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@

import com.google.common.util.concurrent.SimpleTimeLimiter;
import io.airlift.log.Logger;
import io.airlift.units.Duration;
import io.trino.gateway.ha.config.BackendStateConfiguration;
import io.trino.gateway.ha.config.MonitorConfiguration;
import io.trino.gateway.ha.config.ProxyBackendConfiguration;
Expand All @@ -39,6 +40,7 @@ public class ClusterStatsJdbcMonitor
private static final Logger log = Logger.get(ClusterStatsJdbcMonitor.class);

private final Properties properties; // TODO Avoid using a mutable field
private final Duration queryTimeout;

private static final String STATE_QUERY = "SELECT state, COUNT(*) as count "
+ "FROM runtime.queries "
Expand All @@ -51,6 +53,12 @@ public ClusterStatsJdbcMonitor(BackendStateConfiguration backendStateConfigurati
properties.setProperty("user", backendStateConfiguration.getUsername());
properties.setProperty("password", backendStateConfiguration.getPassword());
properties.setProperty("SSL", String.valueOf(backendStateConfiguration.getSsl()));
// explicitPrepare is a valid property for Trino versions >= 431. To avoid compatibility
// issues with versions < 431, this property is left unset when explicitPrepare=true, which is the default
if (!monitorConfiguration.isExplicitPrepare()) {
properties.setProperty("explicitPrepare", "false");
}
queryTimeout = monitorConfiguration.getQueryTimeout();
log.info("state check configured");
}

Expand Down Expand Up @@ -78,6 +86,7 @@ public ClusterStats monitor(ProxyBackendConfiguration backend)
PreparedStatement statement = SimpleTimeLimiter.create(Executors.newSingleThreadExecutor()).callWithTimeout(
() -> conn.prepareStatement(STATE_QUERY), 10, SECONDS)) {
statement.setString(1, (String) properties.get("user"));
statement.setQueryTimeout((int) queryTimeout.roundTo(SECONDS));
Map<String, Integer> partialState = new HashMap<>();
ResultSet rs = statement.executeQuery();
while (rs.next()) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,21 @@
*/
package io.trino.gateway.ha.config;

import io.airlift.units.Duration;
import io.trino.gateway.ha.clustermonitor.ActiveClusterMonitor;

import static java.util.concurrent.TimeUnit.SECONDS;

public class MonitorConfiguration
{
private int taskDelaySeconds = ActiveClusterMonitor.MONITOR_TASK_DELAY_SECONDS;

private int retries;

private Duration queryTimeout = new Duration(10, SECONDS);

private boolean explicitPrepare;

public MonitorConfiguration() {}

public int getTaskDelaySeconds()
Expand All @@ -42,4 +49,24 @@ public void setRetries(int retries)
{
this.retries = retries;
}

public Duration getQueryTimeout()
{
return queryTimeout;
}

public void setQueryTimeout(Duration queryTimeout)
{
this.queryTimeout = queryTimeout;
}

public boolean isExplicitPrepare()
{
return explicitPrepare;
}

public void setExplicitPrepare(boolean explicitPrepare)
{
this.explicitPrepare = explicitPrepare;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@

import io.airlift.http.client.HttpClientConfig;
import io.airlift.http.client.jetty.JettyHttpClient;
import io.airlift.units.Duration;
import io.trino.gateway.ha.config.BackendStateConfiguration;
import io.trino.gateway.ha.config.MonitorConfiguration;
import io.trino.gateway.ha.config.ProxyBackendConfiguration;
Expand All @@ -26,6 +27,7 @@

import java.util.function.Function;

import static java.util.concurrent.TimeUnit.SECONDS;
import static org.assertj.core.api.Assertions.assertThat;
import static org.junit.jupiter.api.TestInstance.Lifecycle.PER_CLASS;
import static org.testcontainers.utility.MountableFile.forClasspathResource;
Expand Down Expand Up @@ -58,7 +60,9 @@ void testHttpMonitor()
@Test
void testJdbcMonitor()
{
testClusterStatsMonitor(backendStateConfiguration -> new ClusterStatsJdbcMonitor(backendStateConfiguration, new MonitorConfiguration()));
MonitorConfiguration monitorConfigurationWithTimeout = new MonitorConfiguration();
monitorConfigurationWithTimeout.setQueryTimeout(new Duration(30, SECONDS));
testClusterStatsMonitor(backendStateConfiguration -> new ClusterStatsJdbcMonitor(backendStateConfiguration, monitorConfigurationWithTimeout));
}

@Test
Expand Down

0 comments on commit 0b8a88b

Please sign in to comment.