All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.jdbc.profile.DriverConfigurationProfiles Maven / Gradle / Ivy

/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package software.amazon.jdbc.profile;

import com.zaxxer.hikari.HikariConfig;
import java.util.Arrays;
import java.util.Collections;
import java.util.Map;
import java.util.Properties;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.TimeUnit;
import org.checkerframework.checker.nullness.qual.NonNull;
import software.amazon.jdbc.HikariPooledConnectionProvider;
import software.amazon.jdbc.HostSpec;
import software.amazon.jdbc.PropertyDefinition;
import software.amazon.jdbc.dialect.Dialect;
import software.amazon.jdbc.plugin.AuroraConnectionTrackerPluginFactory;
import software.amazon.jdbc.plugin.AuroraInitialConnectionStrategyPluginFactory;
import software.amazon.jdbc.plugin.efm2.HostMonitoringConnectionPlugin;
import software.amazon.jdbc.plugin.efm2.HostMonitoringConnectionPluginFactory;
import software.amazon.jdbc.plugin.failover.FailoverConnectionPluginFactory;
import software.amazon.jdbc.plugin.readwritesplitting.ReadWriteSplittingPluginFactory;
import software.amazon.jdbc.plugin.staledns.AuroraStaleDnsPluginFactory;

public class DriverConfigurationProfiles {

  private static final Map presets;

  private static final Map activeProfiles =
      new ConcurrentHashMap<>();

  private static final String MONITORING_CONNECTION_PREFIX = "monitoring-";

  static {
    presets = getConfigurationProfilePresets();
  }

  public static void clear() {
    activeProfiles.clear();
  }

  public static void addOrReplaceProfile(
      @NonNull final String profileName,
      @NonNull final ConfigurationProfile configurationProfile) {
    activeProfiles.put(profileName, configurationProfile);
  }

  public static void remove(@NonNull final String profileName) {
    activeProfiles.remove(profileName);
  }

  public static boolean contains(@NonNull final String profileName) {
    return activeProfiles.containsKey(profileName);
  }

  public static ConfigurationProfile getProfileConfiguration(@NonNull final String profileName) {
    ConfigurationProfile profile = activeProfiles.get(profileName);

    if (profile != null) {
      return profile;
    }
    return presets.get(profileName);
  }

  private static Map getConfigurationProfilePresets() {
    Map presets = new ConcurrentHashMap<>();

    presets.put(ConfigurationProfilePresetCodes.A0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.A0,
            Collections.emptyList(), // empty list is important here! it shouldn't be a null.
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.A1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.A1,
            Collections.emptyList(), // empty list is important here! it shouldn't be a null.
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "30000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "30000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "30000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.A2,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.A2,
            Collections.emptyList(), // empty list is important here! it shouldn't be a null.
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "3000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "3000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "3000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.B,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.B,
            Collections.emptyList(), // empty list is important here! it shouldn't be a null.
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "true"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.C0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.C0,
            Collections.singletonList(HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "60000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "5",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "15000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.C1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.C1,
            Collections.singletonList(HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "30000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "3",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "3000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.D0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.D0,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                ReadWriteSplittingPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.D1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.D1,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                ReadWriteSplittingPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "30000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "30000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "30000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.E,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.E,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                ReadWriteSplittingPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "true"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.F0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.F0,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                ReadWriteSplittingPluginFactory.class,
                FailoverConnectionPluginFactory.class,
                HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "60000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "5",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "15000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.F1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.F1,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                ReadWriteSplittingPluginFactory.class,
                FailoverConnectionPluginFactory.class,
                HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "30000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "3",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "3000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.G0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.G0,
            Arrays.asList(
                AuroraConnectionTrackerPluginFactory.class,
                AuroraStaleDnsPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.G1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.G1,
            Arrays.asList(
                AuroraConnectionTrackerPluginFactory.class,
                AuroraStaleDnsPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "30000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "30000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "30000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.H,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.H,
            Arrays.asList(
                AuroraConnectionTrackerPluginFactory.class,
                AuroraStaleDnsPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "true"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.I0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.I0,
            Arrays.asList(
                AuroraConnectionTrackerPluginFactory.class,
                AuroraStaleDnsPluginFactory.class,
                FailoverConnectionPluginFactory.class,
                HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "60000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "5",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "15000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    presets.put(ConfigurationProfilePresetCodes.I1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.I1,
            Arrays.asList(
                AuroraConnectionTrackerPluginFactory.class,
                AuroraStaleDnsPluginFactory.class,
                FailoverConnectionPluginFactory.class,
                HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "30000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "3",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "3000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            (Dialect) null,
            null,
            null,
            null,
            null));

    // Spring Framework / Spring Boot optimized presets

    presets.put(ConfigurationProfilePresetCodes.SF_D0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.SF_D0,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.SF_D1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.SF_D1,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "30000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "30000",
                PropertyDefinition.LOGIN_TIMEOUT.name, "30000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.SF_E,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.SF_E,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                FailoverConnectionPluginFactory.class),
            getProperties(
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "true"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.SF_F0,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.SF_F0,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                FailoverConnectionPluginFactory.class,
                HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "60000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "5",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "15000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    presets.put(ConfigurationProfilePresetCodes.SF_F1,
        new ConfigurationProfile(
            ConfigurationProfilePresetCodes.SF_F1,
            Arrays.asList(
                AuroraInitialConnectionStrategyPluginFactory.class,
                AuroraConnectionTrackerPluginFactory.class,
                FailoverConnectionPluginFactory.class,
                HostMonitoringConnectionPluginFactory.class),
            getProperties(
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_TIME.name, "30000",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_COUNT.name, "3",
                HostMonitoringConnectionPlugin.FAILURE_DETECTION_INTERVAL.name, "5000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.CONNECT_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.SOCKET_TIMEOUT.name, "3000",
                MONITORING_CONNECTION_PREFIX + PropertyDefinition.LOGIN_TIMEOUT.name, "3000",
                PropertyDefinition.CONNECT_TIMEOUT.name, "10000",
                PropertyDefinition.SOCKET_TIMEOUT.name, "0",
                PropertyDefinition.LOGIN_TIMEOUT.name, "10000",
                PropertyDefinition.TCP_KEEP_ALIVE.name, "false"),
            null,
            null,
            null,
            () -> new HikariPooledConnectionProvider(
                (HostSpec hostSpec, Properties originalProps) -> {
                  final HikariConfig config = new HikariConfig();
                  config.setMaximumPoolSize(30);
                  // holds few extra connections in case of sudden traffic peak
                  config.setMinimumIdle(2);
                  // close idle connection in 15min; helps to get back to normal pool size after load peak
                  config.setIdleTimeout(TimeUnit.MINUTES.toMillis(15));
                  // verify pool configuration and creates no connections during initialization phase
                  config.setInitializationFailTimeout(-1);
                  config.setConnectionTimeout(TimeUnit.SECONDS.toMillis(10));
                  // validate idle connections at least every 3 min
                  config.setKeepaliveTime(TimeUnit.MINUTES.toMillis(3));
                  // allows to quickly validate connection in the pool and move on to another connection if needed
                  config.setValidationTimeout(TimeUnit.SECONDS.toMillis(1));
                  config.setMaxLifetime(TimeUnit.DAYS.toMillis(1));
                  return config;
                },
                null
            ),
            null));

    return presets;
  }

  private static Properties getProperties(String... args) {
    if (args == null) {
      return null;
    }

    if (args.length % 2 != 0) {
      throw new IllegalArgumentException("Properties should be passed by pairs: property name and property value.");
    }

    final Properties props = new Properties();

    for (int i = 0; i < args.length; i += 2) {
      props.put(args[i], args[i + 1]);
    }

    return props;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy