803 lines
33 KiB
Java
803 lines
33 KiB
Java
/*
|
|
* Copyright (c) 2004, PostgreSQL Global Development Group
|
|
* See the LICENSE file in the project root for more information.
|
|
*/
|
|
|
|
package org.postgresql;
|
|
|
|
import org.postgresql.util.DriverInfo;
|
|
import org.postgresql.util.GT;
|
|
import org.postgresql.util.PSQLException;
|
|
import org.postgresql.util.PSQLState;
|
|
|
|
import java.sql.DriverPropertyInfo;
|
|
import java.util.Properties;
|
|
|
|
/**
|
|
* All connection parameters that can be either set in JDBC URL, in Driver properties or in
|
|
* datasource setters.
|
|
*/
|
|
public enum PGProperty {
|
|
|
|
/**
|
|
* If to turn on client encryption feature
|
|
*/
|
|
PG_CLIENT_LOGIC("enable_ce", null,
|
|
"value of 1 is used to turn on the client logic driver feature", false),
|
|
|
|
/**
|
|
* Database name to connect to (may be specified directly in the JDBC URL).
|
|
*/
|
|
PG_DBNAME("PGDBNAME", null,
|
|
"Database name to connect to (may be specified directly in the JDBC URL)", true),
|
|
|
|
/**
|
|
* Hostname of the PostgreSQL server (may be specified directly in the JDBC URL).
|
|
*/
|
|
PG_HOST("PGHOST", null,
|
|
"Hostname of the PostgreSQL server (may be specified directly in the JDBC URL)", false),
|
|
|
|
/**
|
|
* Port of the PostgreSQL server (may be specified directly in the JDBC URL).
|
|
*/
|
|
PG_PORT("PGPORT", null,
|
|
"Port of the PostgreSQL server (may be specified directly in the JDBC URL)"),
|
|
|
|
/**
|
|
* Username to connect to the database as.
|
|
*/
|
|
USER("user", null, "Username to connect to the database as.", true),
|
|
|
|
/**
|
|
* Password to use when authenticating.
|
|
*/
|
|
PASSWORD("password", null, "Password to use when authenticating.", false),
|
|
|
|
/**
|
|
* Force use of a particular protocol version when connecting, if set, disables protocol version
|
|
* fallback.
|
|
*/
|
|
PROTOCOL_VERSION("protocolVersion", null,
|
|
"Force use of a particular protocol version when connecting, currently only version 3 is supported.",
|
|
false, "3"),
|
|
|
|
/**
|
|
* Quote returning columns.
|
|
* There are some ORM's that quote everything, including returning columns
|
|
* If we quote them, then we end up sending ""colname"" to the backend
|
|
* which will not be found
|
|
*/
|
|
QUOTE_RETURNING_IDENTIFIERS("quoteReturningIdentifiers",
|
|
"true",
|
|
"Quote identifiers provided in returning array",
|
|
false),
|
|
|
|
/**
|
|
* <p>Logger level of the driver. Allowed values: {@code OFF}, {@code DEBUG} or {@code TRACE}.</p>
|
|
*
|
|
* <p>This enable the {@link java.util.logging.Logger} of the driver based on the following mapping
|
|
* of levels:</p>
|
|
* <ul>
|
|
* <li>FINE -> DEBUG</li>
|
|
* <li>FINEST -> TRACE</li>
|
|
* </ul>
|
|
*
|
|
* <p><b>NOTE:</b> The recommended approach to enable java.util.logging is using a
|
|
* {@code logging.properties} configuration file with the property
|
|
* {@code -Djava.util.logging.config.file=myfile} or if your are using an application server
|
|
* you should use the appropriate logging subsystem.</p>
|
|
*/
|
|
LOGGER_LEVEL("loggerLevel", null, "Logger level of the driver", false, "OFF", "DEBUG", "TRACE"),
|
|
|
|
/**
|
|
* <p>File name output of the Logger, if set, the Logger will use a
|
|
* {@link java.util.logging.FileHandler} to write to a specified file. If the parameter is not set
|
|
* or the file can't be created the {@link java.util.logging.ConsoleHandler} will be used instead.</p>
|
|
*
|
|
* <p>Parameter should be use together with {@link PGProperty#LOGGER_LEVEL}</p>
|
|
*/
|
|
LOGGER_FILE("loggerFile", null, "File name output of the Logger"),
|
|
LOGGER("logger", null, "logger used by third party application, such as Slf4JLogger"),
|
|
|
|
/**
|
|
* Sets the default threshold for enabling server-side prepare. A value of {@code -1} stands for
|
|
* forceBinary
|
|
*/
|
|
PREPARE_THRESHOLD("prepareThreshold", "5",
|
|
"Statement prepare threshold. A value of {@code -1} stands for forceBinary"),
|
|
|
|
/**
|
|
* Specifies the maximum number of entries in cache of prepared statements. A value of {@code 0}
|
|
* disables the cache.
|
|
*/
|
|
PREPARED_STATEMENT_CACHE_QUERIES("preparedStatementCacheQueries", "256",
|
|
"Specifies the maximum number of entries in per-connection cache of prepared statements. A value of {@code 0} disables the cache."),
|
|
|
|
/**
|
|
* Specifies the maximum size (in megabytes) of the prepared statement cache. A value of {@code 0}
|
|
* disables the cache.
|
|
*/
|
|
PREPARED_STATEMENT_CACHE_SIZE_MIB("preparedStatementCacheSizeMiB", "5",
|
|
"Specifies the maximum size (in megabytes) of a per-connection prepared statement cache. A value of {@code 0} disables the cache."),
|
|
|
|
/**
|
|
* Specifies the maximum number of fields to be cached per connection. A value of {@code 0} disables the cache.
|
|
*/
|
|
DATABASE_METADATA_CACHE_FIELDS("databaseMetadataCacheFields", "65536",
|
|
"Specifies the maximum number of fields to be cached per connection. A value of {@code 0} disables the cache."),
|
|
|
|
/**
|
|
* Specifies the maximum size (in megabytes) of fields to be cached per connection. A value of {@code 0} disables the cache.
|
|
*/
|
|
DATABASE_METADATA_CACHE_FIELDS_MIB("databaseMetadataCacheFieldsMiB", "5",
|
|
"Specifies the maximum size (in megabytes) of fields to be cached per connection. A value of {@code 0} disables the cache."),
|
|
|
|
/**
|
|
* Default parameter for {@link java.sql.Statement#getFetchSize()}. A value of {@code 0} means
|
|
* that need fetch all rows at once
|
|
*/
|
|
DEFAULT_ROW_FETCH_SIZE("defaultRowFetchSize", "0",
|
|
"Positive number of rows that should be fetched from the database when more rows are needed for ResultSet by each fetch iteration"),
|
|
|
|
/**
|
|
* Use binary format for sending and receiving data if possible.
|
|
*/
|
|
BIT_TO_STRING("bitToString", "false",
|
|
"Auto Convert bit or bit(n) to String type in ResultSet.getObject"),
|
|
|
|
/**
|
|
* Use binary format for sending and receiving data if possible.
|
|
*/
|
|
BINARY_TRANSFER("binaryTransfer", "false",
|
|
"Use binary format for sending and receiving data if possible"),
|
|
|
|
/**
|
|
* Puts this connection in read-only mode.
|
|
*/
|
|
READ_ONLY("readOnly", "false", "Puts this connection in read-only mode"),
|
|
|
|
/**
|
|
* Comma separated list of types to enable binary transfer. Either OID numbers or names
|
|
*/
|
|
BINARY_TRANSFER_ENABLE("binaryTransferEnable", "",
|
|
"Comma separated list of types to enable binary transfer. Either OID numbers or names"),
|
|
|
|
/**
|
|
* Comma separated list of types to disable binary transfer. Either OID numbers or names.
|
|
* Overrides values in the driver default set and values set with binaryTransferEnable.
|
|
*/
|
|
BINARY_TRANSFER_DISABLE("binaryTransferDisable", "",
|
|
"Comma separated list of types to disable binary transfer. Either OID numbers or names. Overrides values in the driver default set and values set with binaryTransferEnable."),
|
|
|
|
/**
|
|
* Bind String to either {@code unspecified} or {@code varchar}. Default is {@code varchar} for
|
|
* 8.0+ backends.
|
|
*/
|
|
STRING_TYPE("stringtype", null,
|
|
"The type to bind String parameters as (usually 'varchar', 'unspecified' allows implicit casting to other types)",
|
|
false, "unspecified", "varchar"),
|
|
|
|
/**
|
|
* Specifies the length to return for types of unknown length.
|
|
*/
|
|
UNKNOWN_LENGTH("unknownLength", Integer.toString(Integer.MAX_VALUE),
|
|
"Specifies the length to return for types of unknown length"),
|
|
|
|
/**
|
|
* When connections that are not explicitly closed are garbage collected, log the stacktrace from
|
|
* the opening of the connection to trace the leak source.
|
|
*/
|
|
LOG_UNCLOSED_CONNECTIONS("logUnclosedConnections", "false",
|
|
"When connections that are not explicitly closed are garbage collected, log the stacktrace from the opening of the connection to trace the leak source"),
|
|
|
|
/**
|
|
* Enable optimization that disables column name sanitiser.
|
|
*/
|
|
DISABLE_COLUMN_SANITISER("disableColumnSanitiser", "false",
|
|
"Enable optimization that disables column name sanitiser"),
|
|
|
|
/**
|
|
* Control use of SSL: empty or {@code true} values imply {@code sslmode==verify-full}
|
|
*/
|
|
SSL("ssl", null, "Control use of SSL (any non-null value causes SSL to be required)"),
|
|
|
|
/**
|
|
* Parameter governing the use of SSL. The allowed values are {@code disable}, {@code allow},
|
|
* {@code prefer}, {@code require}, {@code verify-ca}, {@code verify-full}.
|
|
* If {@code ssl} property is empty or set to {@code true} it implies {@code verify-full}.
|
|
* Default mode is "require"
|
|
*/
|
|
SSL_MODE("sslmode", null, "Parameter governing the use of SSL", false,
|
|
"disable", "allow", "prefer", "require", "verify-ca", "verify-full"),
|
|
|
|
/**
|
|
* Context of SSL(SSLContext.getInstance("@code")): empty for TLS,valid values{SSL/SSLv2/SSLv3/TLS/TLSv1/TLSv1.1/TLSv1.2}
|
|
*/
|
|
SSL_CONTEXT("sslcontext", null, "Control use of SSL Context(SSL, TLS, TLSv1.2, etc)"),
|
|
|
|
/**
|
|
* Classname of the SSL Factory to use (instance of {@code javax.net.ssl.SSLSocketFactory}).
|
|
*/
|
|
SSL_FACTORY("sslfactory", null, "Provide a SSLSocketFactory class when using SSL."),
|
|
|
|
/**
|
|
* The String argument to give to the constructor of the SSL Factory.
|
|
* @deprecated use {@code ..Factory(Properties)} constructor.
|
|
*/
|
|
@Deprecated
|
|
SSL_FACTORY_ARG("sslfactoryarg", null,
|
|
"Argument forwarded to constructor of SSLSocketFactory class."),
|
|
|
|
/**
|
|
* Classname of the SSL HostnameVerifier to use (instance of {@code
|
|
* javax.net.ssl.HostnameVerifier}).
|
|
*/
|
|
SSL_HOSTNAME_VERIFIER("sslhostnameverifier", null,
|
|
"A class, implementing javax.net.ssl.HostnameVerifier that can verify the server"),
|
|
|
|
/**
|
|
* File containing the SSL Certificate. Default will be the file {@code postgresql.crt} in {@code
|
|
* $HOME/.postgresql} (*nix) or {@code %APPDATA%\postgresql} (windows).
|
|
*/
|
|
SSL_CERT("sslcert", null, "The location of the client's SSL certificate"),
|
|
|
|
/**
|
|
* File containing the SSL Key. Default will be the file {@code postgresql.pk8} in {@code
|
|
* $HOME/.postgresql} (*nix) or {@code %APPDATA%\postgresql} (windows).
|
|
*/
|
|
SSL_KEY("sslkey", null, "The location of the client's PKCS#8 SSL key"),
|
|
|
|
/**
|
|
* File containing the root certificate when validating server ({@code sslmode} = {@code
|
|
* verify-ca} or {@code verify-full}). Default will be the file {@code root.crt} in {@code
|
|
* $HOME/.postgresql} (*nix) or {@code %APPDATA%\postgresql} (windows).
|
|
*/
|
|
SSL_ROOT_CERT("sslrootcert", null,
|
|
"The location of the root certificate for authenticating the server."),
|
|
|
|
/**
|
|
* The SSL password to use in the default CallbackHandler.
|
|
*/
|
|
SSL_PASSWORD("sslpassword", null,
|
|
"The password for the client's ssl key (ignored if sslpasswordcallback is set)"),
|
|
|
|
SSL_PRIVATEKEY_FACTORY("sslprivatekeyfactory", null,
|
|
"The privatekey factory for the client's ssl"),
|
|
|
|
/**
|
|
* The classname instantiating {@code javax.security.auth.callback.CallbackHandler} to use.
|
|
*/
|
|
SSL_PASSWORD_CALLBACK("sslpasswordcallback", null,
|
|
"A class, implementing javax.security.auth.callback.CallbackHandler that can handle PassworCallback for the ssl password."),
|
|
|
|
/**
|
|
* Enable or disable TCP keep-alive. The default is {@code false}.
|
|
*/
|
|
TCP_KEEP_ALIVE("tcpKeepAlive", "false",
|
|
"Enable or disable TCP keep-alive. The default is {@code false}."),
|
|
|
|
/**
|
|
* Specify how long to wait for establishment of a database connection. The timeout is specified
|
|
* in seconds.
|
|
*/
|
|
LOGIN_TIMEOUT("loginTimeout", "0",
|
|
"Specify how long to wait for establishment of a database connection."),
|
|
|
|
/**
|
|
* <p>The timeout value used for socket connect operations. If connecting to the server takes longer
|
|
* than this value, the connection is broken.</p>
|
|
*
|
|
* <p>The timeout is specified in seconds and a value of zero means that it is disabled.</p>
|
|
*/
|
|
CONNECT_TIMEOUT("connectTimeout", "0", "The timeout value used for socket connect operations."),
|
|
|
|
/**
|
|
* The timeout value used for socket read operations. If reading from the server takes longer than
|
|
* this value, the connection is closed. This can be used as both a brute force global query
|
|
* timeout and a method of detecting network problems. The timeout is specified in seconds and a
|
|
* value of zero means that it is disabled.
|
|
*/
|
|
SOCKET_TIMEOUT("socketTimeout", "0", "The timeout value used for socket read operations."),
|
|
|
|
/**
|
|
* The timeout value used for socket read operations when jdbc connecting. If reading from the server takes longer than
|
|
* this value, the connection is closed. This can be used as both a brute force global query
|
|
* timeout and a method of detecting network problems. The timeout is specified in seconds and a
|
|
* value of zero means that it is disabled.
|
|
*/
|
|
SOCKET_TIMEOUT_IN_CONNECTING("socketTimeoutInConnecting", "5", "The timeout value used for socket read operations when jdbc connecting."),
|
|
|
|
/**
|
|
* Cancel command is sent out of band over its own connection, so cancel message can itself get
|
|
* stuck.
|
|
* This property controls "connect timeout" and "socket timeout" used for cancel commands.
|
|
* The timeout is specified in seconds. Default value is 10 seconds.
|
|
*/
|
|
CANCEL_SIGNAL_TIMEOUT("cancelSignalTimeout", "10", "The timeout that is used for sending cancel command."),
|
|
|
|
/**
|
|
* Socket factory used to create socket. A null value, which is the default, means system default.
|
|
*/
|
|
SOCKET_FACTORY("socketFactory", null, "Specify a socket factory for socket creation"),
|
|
|
|
/**
|
|
* The String argument to give to the constructor of the Socket Factory.
|
|
* @deprecated use {@code ..Factory(Properties)} constructor.
|
|
*/
|
|
@Deprecated
|
|
SOCKET_FACTORY_ARG("socketFactoryArg", null,
|
|
"Argument forwarded to constructor of SocketFactory class."),
|
|
|
|
/**
|
|
* Socket read buffer size (SO_RECVBUF). A value of {@code -1}, which is the default, means system
|
|
* default.
|
|
*/
|
|
RECEIVE_BUFFER_SIZE("receiveBufferSize", "-1", "Socket read buffer size"),
|
|
|
|
/**
|
|
* Socket write buffer size (SO_SNDBUF). A value of {@code -1}, which is the default, means system
|
|
* default.
|
|
*/
|
|
SEND_BUFFER_SIZE("sendBufferSize", "-1", "Socket write buffer size"),
|
|
|
|
/**
|
|
* Assume the server is at least that version.
|
|
*/
|
|
ASSUME_MIN_SERVER_VERSION("assumeMinServerVersion", null,
|
|
"Assume the server is at least that version"),
|
|
|
|
/**
|
|
* The application name (require server version >= 9.0).
|
|
*/
|
|
APPLICATION_NAME("ApplicationName", DriverInfo.DRIVER_NAME, "Name of the Application (backend >= 9.0)"),
|
|
|
|
APPLICATION_TYPE("ApplicationType", null, "Application Type"),
|
|
|
|
/**
|
|
* Flag to enable/disable obtaining a GSS credential via JAAS login before authenticating.
|
|
* Useful if setting system property javax.security.auth.useSubjectCredsOnly=false
|
|
* or using native GSS with system property sun.security.jgss.native=true
|
|
*/
|
|
JAAS_LOGIN("jaasLogin", "true", "Login with JAAS before doing GSSAPI authentication"),
|
|
|
|
/**
|
|
* Specifies the name of the JAAS system or application login configuration.
|
|
*/
|
|
JAAS_APPLICATION_NAME("jaasApplicationName", null,
|
|
"Specifies the name of the JAAS system or application login configuration."),
|
|
|
|
/**
|
|
* The Kerberos service name to use when authenticating with GSSAPI. This is equivalent to libpq's
|
|
* PGKRBSRVNAME environment variable.
|
|
*/
|
|
KERBEROS_SERVER_NAME("kerberosServerName", null,
|
|
"The Kerberos service name to use when authenticating with GSSAPI."),
|
|
|
|
/**
|
|
* Use SPNEGO in SSPI authentication requests.
|
|
*/
|
|
USE_SPNEGO("useSpnego", "false", "Use SPNEGO in SSPI authentication requests"),
|
|
|
|
/**
|
|
* Force one of
|
|
* <ul>
|
|
* <li>SSPI (Windows transparent single-sign-on)</li>
|
|
* <li>GSSAPI (Kerberos, via JSSE)</li>
|
|
* </ul>
|
|
* to be used when the server requests Kerberos or SSPI authentication.
|
|
*/
|
|
GSS_LIB("gsslib", "auto", "Force SSSPI or GSSAPI", false, "auto", "sspi", "gssapi"),
|
|
|
|
/**
|
|
* Specifies the name of the SSPI service class that forms the service class part of the SPN. The
|
|
* default, {@code POSTGRES}, is almost always correct.
|
|
*/
|
|
SSPI_SERVICE_CLASS("sspiServiceClass", "POSTGRES", "The Windows SSPI service class for SPN"),
|
|
|
|
/**
|
|
* When using the V3 protocol the driver monitors changes in certain server configuration
|
|
* parameters that should not be touched by end users. The {@code client_encoding} setting is set
|
|
* by the driver and should not be altered. If the driver detects a change it will abort the
|
|
* connection.
|
|
*/
|
|
ALLOW_ENCODING_CHANGES("allowEncodingChanges", "false", "Allow for changes in client_encoding"),
|
|
|
|
/**
|
|
* Specify the schema to be set in the search-path. This schema will be used to resolve
|
|
* unqualified object names used in statements over this connection.
|
|
*/
|
|
CURRENT_SCHEMA("currentSchema", null, "Specify the schema to be set in the search-path"),
|
|
|
|
TARGET_SERVER_TYPE("targetServerType", "any", "Specifies what kind of server to connect", false,
|
|
"any", "master", "slave", "secondary", "preferSlave", "preferSecondary"),
|
|
|
|
/**
|
|
* Specify the number of nodes to be connected first
|
|
*/
|
|
PRIORITY_SERVERS("priorityServers",null,"Specify the number of nodes to be connected first"),
|
|
|
|
/**
|
|
* When using the priority load balancing feature, if use the node_host field of the pgxc_node table
|
|
* Load balancing feature will be invalid, So we use EIP uniformly unless data IP must be used.
|
|
*/
|
|
USING_EIP("usingEip", "true", "Use elastic IP address when loadBalance"),
|
|
|
|
LOAD_BALANCE_HOSTS("loadBalanceHosts", "false",
|
|
"If disabled hosts are connected in the given order. If enabled hosts are chosen randomly from the set of suitable candidates"),
|
|
|
|
HOST_RECHECK_SECONDS("hostRecheckSeconds", "10",
|
|
"Specifies period (seconds) after which the host status is checked again in case it has changed"),
|
|
|
|
FORCE_TARGET_SERVER_SLAVE("forceTargetServerSlave", "false",
|
|
"whether to close old connections to standby node once it was promoted as primary node."),
|
|
|
|
/**
|
|
* <p>Specifies which mode is used to execute queries to database: simple means ('Q' execute, no parse, no bind, text mode only),
|
|
* extended means always use bind/execute messages, extendedForPrepared means extended for prepared statements only,
|
|
* extendedCacheEverything means use extended protocol and try cache every statement (including Statement.execute(String sql)) in a query cache.</p>
|
|
*
|
|
* <p>This mode is meant for debugging purposes and/or for cases when extended protocol cannot be used (e.g. logical replication protocol)</p>
|
|
*/
|
|
PREFER_QUERY_MODE("preferQueryMode", "extended",
|
|
"Specifies which mode is used to execute queries to database: simple means ('Q' execute, no parse, no bind, text mode only), "
|
|
+ "extended means always use bind/execute messages, extendedForPrepared means extended for prepared statements only, "
|
|
+ "extendedCacheEverything means use extended protocol and try cache every statement (including Statement.execute(String sql)) in a query cache.", false,
|
|
"extended", "extendedForPrepared", "extendedCacheEverything", "simple"),
|
|
|
|
/**
|
|
* Specifies what the driver should do if a query fails. In {@code autosave=always} mode, JDBC driver sets a savepoint before each query,
|
|
* and rolls back to that savepoint in case of failure. In {@code autosave=never} mode (default), no savepoint dance is made ever.
|
|
* In {@code autosave=conservative} mode, savepoint is set for each query, however the rollback is done only for rare cases
|
|
* like 'cached statement cannot change return type' or 'statement XXX is not valid' so JDBC driver rollsback and retries
|
|
*/
|
|
AUTOSAVE("autosave", "never",
|
|
"Specifies what the driver should do if a query fails. In autosave=always mode, JDBC driver sets a savepoint before each query, "
|
|
+ "and rolls back to that savepoint in case of failure. In autosave=never mode (default), no savepoint dance is made ever. "
|
|
+ "In autosave=conservative mode, safepoint is set for each query, however the rollback is done only for rare cases"
|
|
+ " like 'cached statement cannot change return type' or 'statement XXX is not valid' so JDBC driver rollsback and retries", false,
|
|
"always", "never", "conservative"),
|
|
|
|
/**
|
|
* Configure optimization to enable batch insert re-writing.
|
|
*/
|
|
REWRITE_BATCHED_INSERTS("reWriteBatchedInserts", "false",
|
|
"Enable optimization to rewrite and collapse compatible INSERT statements that are batched."),
|
|
|
|
/**
|
|
* <p>Connection parameter passed in the startup message. This parameter accepts two values; "true"
|
|
* and "database". Passing "true" tells the backend to go into walsender mode, wherein a small set
|
|
* of replication commands can be issued instead of SQL statements. Only the simple query protocol
|
|
* can be used in walsender mode. Passing "database" as the value instructs walsender to connect
|
|
* to the database specified in the dbname parameter, which will allow the connection to be used
|
|
* for logical replication from that database.</p>
|
|
* <p>Parameter should be use together with {@link PGProperty#ASSUME_MIN_SERVER_VERSION} with
|
|
* parameter >= 9.4 (backend >= 9.4)</p>
|
|
*/
|
|
REPLICATION("replication", null,
|
|
"Connection parameter passed in startup message, one of 'true' or 'database' "
|
|
+ "Passing 'true' tells the backend to go into walsender mode, "
|
|
+ "wherein a small set of replication commands can be issued instead of SQL statements. "
|
|
+ "Only the simple query protocol can be used in walsender mode. "
|
|
+ "Passing 'database' as the value instructs walsender to connect "
|
|
+ "to the database specified in the dbname parameter, "
|
|
+ "which will allow the connection to be used for logical replication "
|
|
+ "from that database. "
|
|
+ "(backend >= 9.4)"),
|
|
|
|
/**
|
|
* Enable quick auto balancing.
|
|
*
|
|
*/
|
|
ENABLE_QUICK_AUTO_BALANCE("enableQuickAutoBalance", "false",
|
|
"If the connection enable quickAutoBalance, this parameter only takes effect when autoBalance=leastconn."
|
|
+ "value: true or false.",
|
|
false, "true", "false"),
|
|
|
|
/**
|
|
* Idle time threshold of connections when quick auto balancing filters connections.
|
|
*/
|
|
MAX_IDLE_TIME_BEFORE_TERMINAL("maxIdleTimeBeforeTerminal", "30",
|
|
"During quick load balancing, if the connection is idle for more than maxIdleTimeBeforeTerminal seconds, "
|
|
+ "the connection may be closed to achieve load balancing for each data node."
|
|
+ "Value range: long && [0, Long.MAX_VALUE / 1000]."
|
|
+ "This parameter only takes effect when autoBalance=leastconn and enableQuickAutoBalance=true"),
|
|
|
|
/**
|
|
* Percentage of min reserved connections pre cluster when executing quick auto balancing.
|
|
*/
|
|
MIN_RESERVED_CON_PER_CLUSTER("minReservedConPerCluster", null,
|
|
"Percentage of min reserved connections pre cluster when executing quick auto balancing, "
|
|
+ "jdbc will retain minReservedConPerCluster percent of the connections per cluster that meet the closing conditions during quick auto balancing."
|
|
+ "Value range: int && [0, 100]."
|
|
+ "This parameter only takes effect when autoBalance=leastconn and enableQuickAutoBalance=true"),
|
|
|
|
/**
|
|
* Percentage of min reserved connections pre data node when executing quick auto balancing.
|
|
*/
|
|
MIN_RESERVED_CON_PER_DATANODE("minReservedConPerDatanode", null,
|
|
"Percentage of min reserved connections pre data node when executing quick auto balancing, "
|
|
+ "jdbc will retain minReservedConPerCluster percent of the connections pre data node that meet the closing conditions during quick auto balancing."
|
|
+ "Value range: int && [0, 100]."
|
|
+ "This parameter only takes effect when autoBalance=leastconn and enableQuickAutoBalance=true"),
|
|
|
|
/**
|
|
* Enable statement load balance.
|
|
*/
|
|
ENABLE_STATEMENT_LOAD_BALANCE("enableStatementLoadBalance", "false",
|
|
"Enable statement-level load balancing configuration, "
|
|
+ "so that load balancing routing will be performed when each SQL statement is executed."
|
|
+ "Optional values: true or false.",
|
|
false, "true", "false"),
|
|
|
|
/**
|
|
* Write data source address.
|
|
*/
|
|
WRITE_DATA_SOURCE_ADDRESS("writeDataSourceAddress", "", "Specify the host and port for write database", false),
|
|
|
|
/**
|
|
* Supported TLS cipher suites
|
|
*/
|
|
TLS_CIPHERS_SUPPERTED("TLSCiphersSupperted",
|
|
"TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,"
|
|
+ "TLS_DHE_RSA_WITH_AES_256_GCM_SHA384,"
|
|
+ "TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,"
|
|
+ "TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,"
|
|
+ "TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,"
|
|
+ "TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384",
|
|
"Supported TLS cipher suites"),
|
|
|
|
/**
|
|
* Factory class to instantiate factories for XML processing.
|
|
* The default factory disables external entity processing.
|
|
* Legacy behavior with external entity processing can be enabled by specifying a value of LEGACY_INSECURE.
|
|
* Or specify a custom class that implements {@code org.postgresql.xml.PGXmlFactoryFactory}.
|
|
*/
|
|
XML_FACTORY_FACTORY(
|
|
"xmlFactoryFactory",
|
|
"",
|
|
"Factory class to instantiate factories for XML processing"),
|
|
|
|
/**
|
|
* It is used to detect the thread interval of the survival task on the primary node in the high availability scenario.
|
|
*/
|
|
HEARTBEAT_PERIOD("heartbeatPeriod", "0", "heartbeat interval time"),
|
|
|
|
/**
|
|
* It is used to change timestamp parameter in TimestampUtils convert.
|
|
*/
|
|
TIMESTAMP_NANO_FORMAT("timestampNanoFormat", "0", "0 main's already add nana seconds. 1 mains nano<1000 will not add"),
|
|
|
|
/**
|
|
* In the scenario where heartbeat maintenance is enabled for the active node,
|
|
* if the active node is down, set the timeout threshold for searching for the active node.
|
|
* If the active node is not detected within this timeout period,
|
|
* the cluster is considered to have no active node and no maintenance is performed on the current cluster.
|
|
* This time should include the RTO time of the active node。
|
|
*/
|
|
MASTER_FAILURE_HEARTBEAT_TIMEOUT("masterFailureHeartbeatTimeout", "30000", "In the scenario where heartbeat maintenance is enabled for the active node, " +
|
|
"if the active node is down, set the timeout threshold for searching for the active node. If the active node is not detected within this timeout period, " +
|
|
"the cluster is considered to have no active node and no maintenance is performed on the current cluster. This time should include the RTO time of the active node."),
|
|
|
|
/**
|
|
* Adaptively modify the inconsistent set sqlType in batch mode. If the first set sqlType is INTEGER and
|
|
* the second set is LONG, the first one will be automatically modify to LONG
|
|
*/
|
|
ADAPTIVE_SET_SQL_TYPE("adaptiveSetSQLType", "false", "Adaptively modify the inconsistent set sqlType in batch mode. If the first set sqlType is INTEGER and" +
|
|
" the second set is LONG, the first one will be automatically modify to LONG"),
|
|
|
|
/**
|
|
* Specify 'options' connection initialization parameter.
|
|
* The value of this parameter may contain spaces and other special characters or their URL representation.
|
|
*/
|
|
OPTIONS("options", null, "Specify 'options' connection initialization parameter."),
|
|
|
|
B_CMPT_MODE("BCmptMode", "false", "Specify 'dolphin.b_compatibility_mode'"
|
|
+ " connection initialization parameter."),
|
|
;
|
|
|
|
private String _name;
|
|
private String _defaultValue;
|
|
private boolean _required;
|
|
private String _description;
|
|
private String[] _choices;
|
|
|
|
PGProperty(String name, String defaultValue, String description) {
|
|
this(name, defaultValue, description, false);
|
|
}
|
|
|
|
PGProperty(String name, String defaultValue, String description, boolean required) {
|
|
this(name, defaultValue, description, required, (String[]) null);
|
|
}
|
|
|
|
PGProperty(String name, String defaultValue, String description, boolean required,
|
|
String... choices) {
|
|
_name = name;
|
|
_defaultValue = defaultValue;
|
|
_required = required;
|
|
_description = description;
|
|
_choices = choices;
|
|
}
|
|
|
|
/**
|
|
* Returns the name of the connection parameter. The name is the key that must be used in JDBC URL
|
|
* or in Driver properties
|
|
*
|
|
* @return the name of the connection parameter
|
|
*/
|
|
public String getName() {
|
|
return _name;
|
|
}
|
|
|
|
/**
|
|
* Returns the default value for this connection parameter.
|
|
*
|
|
* @return the default value for this connection parameter or null
|
|
*/
|
|
public String getDefaultValue() {
|
|
return _defaultValue;
|
|
}
|
|
|
|
/**
|
|
* Returns the available values for this connection parameter.
|
|
*
|
|
* @return the available values for this connection parameter or null
|
|
*/
|
|
public String[] getChoices() {
|
|
return _choices;
|
|
}
|
|
|
|
/**
|
|
* Returns the value of the connection parameters according to the given {@code Properties} or the
|
|
* default value.
|
|
*
|
|
* @param properties properties to take actual value from
|
|
* @return evaluated value for this connection parameter
|
|
*/
|
|
public String get(Properties properties) {
|
|
return properties.getProperty(_name, _defaultValue);
|
|
}
|
|
|
|
/**
|
|
* Set the value for this connection parameter in the given {@code Properties}.
|
|
*
|
|
* @param properties properties in which the value should be set
|
|
* @param value value for this connection parameter
|
|
*/
|
|
public void set(Properties properties, String value) {
|
|
if (value == null) {
|
|
properties.remove(_name);
|
|
} else {
|
|
properties.setProperty(_name, value);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return the boolean value for this connection parameter in the given {@code Properties}.
|
|
*
|
|
* @param properties properties to take actual value from
|
|
* @return evaluated value for this connection parameter converted to boolean
|
|
*/
|
|
public boolean getBoolean(Properties properties) {
|
|
return Boolean.valueOf(get(properties));
|
|
}
|
|
|
|
/**
|
|
* Return the int value for this connection parameter in the given {@code Properties}. Prefer the
|
|
* use of {@link #getInt(Properties)} anywhere you can throw an {@link java.sql.SQLException}.
|
|
*
|
|
* @param properties properties to take actual value from
|
|
* @return evaluated value for this connection parameter converted to int
|
|
* @throws NumberFormatException if it cannot be converted to int.
|
|
*/
|
|
public int getIntNoCheck(Properties properties) {
|
|
String value = get(properties);
|
|
return Integer.parseInt(value);
|
|
}
|
|
|
|
/**
|
|
* Return the int value for this connection parameter in the given {@code Properties}.
|
|
*
|
|
* @param properties properties to take actual value from
|
|
* @return evaluated value for this connection parameter converted to int
|
|
* @throws PSQLException if it cannot be converted to int.
|
|
*/
|
|
public int getInt(Properties properties) throws PSQLException {
|
|
String value = get(properties);
|
|
try {
|
|
return Integer.parseInt(value);
|
|
} catch (NumberFormatException nfe) {
|
|
throw new PSQLException(GT.tr("{0} parameter value must be an integer but was: {1}",
|
|
getName(), value), PSQLState.INVALID_PARAMETER_VALUE, nfe);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return the {@code Integer} value for this connection parameter in the given {@code Properties}.
|
|
*
|
|
* @param properties properties to take actual value from
|
|
* @return evaluated value for this connection parameter converted to Integer or null
|
|
* @throws PSQLException if unable to parse property as integer
|
|
*/
|
|
public Integer getInteger(Properties properties) throws PSQLException {
|
|
String value = get(properties);
|
|
if (value == null) {
|
|
return null;
|
|
}
|
|
try {
|
|
return Integer.parseInt(value);
|
|
} catch (NumberFormatException nfe) {
|
|
throw new PSQLException(GT.tr("{0} parameter value must be an integer but was: {1}",
|
|
getName(), value), PSQLState.INVALID_PARAMETER_VALUE, nfe);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Set the boolean value for this connection parameter in the given {@code Properties}.
|
|
*
|
|
* @param properties properties in which the value should be set
|
|
* @param value boolean value for this connection parameter
|
|
*/
|
|
public void set(Properties properties, boolean value) {
|
|
properties.setProperty(_name, Boolean.toString(value));
|
|
}
|
|
|
|
/**
|
|
* Set the int value for this connection parameter in the given {@code Properties}.
|
|
*
|
|
* @param properties properties in which the value should be set
|
|
* @param value int value for this connection parameter
|
|
*/
|
|
public void set(Properties properties, int value) {
|
|
properties.setProperty(_name, Integer.toString(value));
|
|
}
|
|
|
|
/**
|
|
* Test whether this property is present in the given {@code Properties}.
|
|
*
|
|
* @param properties set of properties to check current in
|
|
* @return true if the parameter is specified in the given properties
|
|
*/
|
|
public boolean isPresent(Properties properties) {
|
|
return getSetString(properties) != null;
|
|
}
|
|
|
|
/**
|
|
* Convert this connection parameter and the value read from the given {@code Properties} into a
|
|
* {@code DriverPropertyInfo}.
|
|
*
|
|
* @param properties properties to take actual value from
|
|
* @return a DriverPropertyInfo representing this connection parameter
|
|
*/
|
|
public DriverPropertyInfo toDriverPropertyInfo(Properties properties) {
|
|
DriverPropertyInfo propertyInfo = new DriverPropertyInfo(_name, get(properties));
|
|
propertyInfo.required = _required;
|
|
propertyInfo.description = _description;
|
|
propertyInfo.choices = _choices;
|
|
return propertyInfo;
|
|
}
|
|
|
|
public static PGProperty forName(String name) {
|
|
for (PGProperty property : PGProperty.values()) {
|
|
if (property.getName().equals(name)) {
|
|
return property;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* Return the property if exists but avoiding the default. Allowing the caller to detect the lack
|
|
* of a property.
|
|
*
|
|
* @param properties properties bundle
|
|
* @return the value of a set property
|
|
*/
|
|
public String getSetString(Properties properties) {
|
|
Object o = properties.get(_name);
|
|
if (o instanceof String) {
|
|
return (String) o;
|
|
}
|
|
return null;
|
|
}
|
|
}
|