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

io.hekate.cluster.seed.jdbc.JdbcSeedNodeProviderConfig Maven / Gradle / Ivy

/*
 * Copyright 2022 The Hekate Project
 *
 * The Hekate Project licenses this file to you 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 io.hekate.cluster.seed.jdbc;

import io.hekate.cluster.seed.SeedNodeProvider;
import io.hekate.util.format.ToString;
import java.sql.Statement;
import javax.sql.DataSource;

/**
 * Configuration for {@link JdbcSeedNodeProvider}.
 *
 * 

Database structure

*

* By default the following database table should exist in the target database: *

*
{@code
 * CREATE TABLE cluster_nodes (
 *      namespace VARCHAR,
 *      host VARCHAR,
 *      port NUMBER
 * )
 * }
* *

* It is possible to modify table and column names by using the following properties: *

*
    *
  • {@link #setTable(String)} - table name (default is {@value #DEFAULT_TABLE})
  • *
  • {@link #setNamespaceColumn(String)} - column to store cluster namespace (default is {@value #DEFAULT_NAMESPACE_COLUMN})
  • *
  • {@link #setHostColumn(String)} - column to store host address (default is {@value #DEFAULT_HOST_COLUMN})
  • *
  • {@link #setPortColumn(String)} - column to store port value (default is {@value #DEFAULT_PORT_COLUMN})
  • *
* *

Database connectivity

*

* Database connectivity is controlled by the following properties: *

*
    *
  • {@link #setDataSource(DataSource)} - JDBC datasource to be used for obtaining database connections
  • *
  • {@link #setQueryTimeout(int)} - optional timeout value for SQL queries (see {@link Statement#setQueryTimeout(int)})
  • *
* * @see JdbcSeedNodeProvider */ public class JdbcSeedNodeProviderConfig { /** Default value (={@value}) for {@link #setCleanupInterval(long)}. */ public static final long DEFAULT_CLEANUP_INTERVAL = 60_000; /** Default value (={@value}) for {@link #setTable(String)}. */ public static final String DEFAULT_TABLE = "cluster_nodes"; /** Default value (={@value}) for {@link #setHostColumn(String)}. */ public static final String DEFAULT_HOST_COLUMN = "host"; /** Default value (={@value}) for {@link #setPortColumn(String)}. */ public static final String DEFAULT_PORT_COLUMN = "port"; /** Default value (={@value}) for {@link #setNamespaceColumn(String)}. */ public static final String DEFAULT_NAMESPACE_COLUMN = "cluster_namespace"; /** See {@link #setDataSource(DataSource)}. */ private DataSource dataSource; /** See {@link #setCleanupInterval(long)}. */ private long cleanupInterval = DEFAULT_CLEANUP_INTERVAL; /** See {@link #setQueryTimeout(int)}. */ private int queryTimeout; /** See {@link #setTable(String)}. */ private String table = DEFAULT_TABLE; /** See {@link #setHostColumn(String)}. */ private String hostColumn = DEFAULT_HOST_COLUMN; /** See {@link #setPortColumn(String)}. */ private String portColumn = DEFAULT_PORT_COLUMN; /** See {@link #setNamespaceColumn(String)}. */ private String namespaceColumn = DEFAULT_NAMESPACE_COLUMN; /** * Returns the data source (see {@link #setDataSource(DataSource)}). * * @return Data source */ public DataSource getDataSource() { return dataSource; } /** * Sets the data source. * * @param dataSource Data source. */ public void setDataSource(DataSource dataSource) { this.dataSource = dataSource; } /** * Fluent-style version of {@link #setDataSource(DataSource)}. * * @param dataSource Data source. * * @return This instance. */ public JdbcSeedNodeProviderConfig withDataSource(DataSource dataSource) { setDataSource(dataSource); return this; } /** * Returns the table name (see {@link #setTable(String)}). * * @return Table name. */ public String getTable() { return table; } /** * Sets the table name. * *

* Default value of this parameter is {@value #DEFAULT_TABLE}. *

* * @param table Table name. */ public void setTable(String table) { this.table = table; } /** * Fluent-style version of {@link #setTable(String)}. * * @param table Table name. * * @return This instance. */ public JdbcSeedNodeProviderConfig withTable(String table) { setTable(table); return this; } /** * Returns the host column name (see {@link #setHostColumn(String)}). * * @return Host column name. */ public String getHostColumn() { return hostColumn; } /** * Sets the host column name. * *

* Default value of this parameter is {@value #DEFAULT_HOST_COLUMN}. *

* * @param hostColumn Host column name. */ public void setHostColumn(String hostColumn) { this.hostColumn = hostColumn; } /** * Fluent-style version of {@link #setHostColumn(String)}. * * @param hostColumn Host column name. * * @return This instance. */ public JdbcSeedNodeProviderConfig withHostColumn(String hostColumn) { setHostColumn(hostColumn); return this; } /** * Returns the port column name (see {@link #setPortColumn(String)}). * * @return Port column name. */ public String getPortColumn() { return portColumn; } /** * Sets the port column name. * *

* Default value of this parameter is {@value #DEFAULT_PORT_COLUMN}. *

* * @param portColumn Port column name. */ public void setPortColumn(String portColumn) { this.portColumn = portColumn; } /** * Fluent-style version of {@link #setPortColumn(String)}. * * @param portColumn Port column name. * * @return This instance. */ public JdbcSeedNodeProviderConfig withPortColumn(String portColumn) { setPortColumn(portColumn); return this; } /** * Returns the cluster column name (see {@link #setNamespaceColumn(String)}). * * @return Cluster column name. */ public String getNamespaceColumn() { return namespaceColumn; } /** * Sets the cluster column name. * *

* Default value of this parameter is {@value #DEFAULT_NAMESPACE_COLUMN}. *

* * @param namespaceColumn Cluster column name. */ public void setNamespaceColumn(String namespaceColumn) { this.namespaceColumn = namespaceColumn; } /** * Fluent-style version of {@link #setNamespaceColumn(String)}. * * @param namespaceColumn Namespace column name. * * @return This instance. */ public JdbcSeedNodeProviderConfig withNamespaceColumn(String namespaceColumn) { setNamespaceColumn(namespaceColumn); return this; } /** * Returns the JDBC query timeout (see {@link #setQueryTimeout(int)}). * * @return Timeout in seconds. */ public int getQueryTimeout() { return queryTimeout; } /** * Sets the JDBC query timeout value in seconds. * *

* If this parameter is set to a positive value then such timeout will be set via {@link Statement#setQueryTimeout(int)} for all * database queries. *

* * @param queryTimeout Timeout in seconds. */ public void setQueryTimeout(int queryTimeout) { this.queryTimeout = queryTimeout; } /** * Fluent-style version of {@link #setQueryTimeout(int)}. * * @param queryTimeout Timeout in seconds. * * @return This instance. */ public JdbcSeedNodeProviderConfig withQueryTimeout(int queryTimeout) { setQueryTimeout(queryTimeout); return this; } /** * Returns the time interval in milliseconds between stale node cleanup runs (see {@link #setCleanupInterval(long)}). * * @return Time interval in milliseconds. */ public long getCleanupInterval() { return cleanupInterval; } /** * Sets the time interval in milliseconds between stale node cleanup runs. * *

Default value of this parameter is {@value #DEFAULT_CLEANUP_INTERVAL}.

* *

* For more details please see the documentation of {@link SeedNodeProvider}. *

* * @param cleanupInterval Time interval in milliseconds. * * @see SeedNodeProvider#cleanupInterval() */ public void setCleanupInterval(long cleanupInterval) { this.cleanupInterval = cleanupInterval; } /** * Fluent-style version of {@link #setCleanupInterval(long)}. * * @param cleanupInterval Time interval in milliseconds. * * @return This instance. */ public JdbcSeedNodeProviderConfig withCleanupInterval(long cleanupInterval) { setCleanupInterval(cleanupInterval); return this; } @Override public String toString() { return ToString.format(this); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy