org.redisson.config.BaseConfig Maven / Gradle / Ivy
Show all versions of redisson Show documentation
/**
* Copyright (c) 2013-2024 Nikita Koksharov
*
* 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 org.redisson.config;
import org.redisson.api.NameMapper;
import org.redisson.client.DefaultCredentialsResolver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.net.ssl.KeyManagerFactory;
import javax.net.ssl.TrustManagerFactory;
import java.net.URL;
/**
*
* @author Nikita Koksharov
*
* @param config type
*/
public class BaseConfig> {
protected static final Logger log = LoggerFactory.getLogger("config");
/**
* If pooled connection not used for a timeout
time
* and current connections amount bigger than minimum idle connections pool size,
* then it will closed and removed from pool.
* Value in milliseconds.
*
*/
private int idleConnectionTimeout = 10000;
/**
* Timeout during connecting to any Redis server.
* Value in milliseconds.
*
*/
private int connectTimeout = 10000;
/**
* Redis server response timeout. Starts to countdown when Redis command was succesfully sent.
* Value in milliseconds.
*
*/
private int timeout = 3000;
private int subscriptionTimeout = 7500;
private int retryAttempts = 3;
private int retryInterval = 1500;
/**
* Password for Redis authentication. Should be null if not needed
*/
private String password;
private String username;
private CredentialsResolver credentialsResolver = new DefaultCredentialsResolver();
/**
* Subscriptions per Redis connection limit
*/
private int subscriptionsPerConnection = 5;
/**
* Name of client connection
*/
private String clientName;
private SslVerificationMode sslVerificationMode = SslVerificationMode.STRICT;
private String sslKeystoreType;
private SslProvider sslProvider = SslProvider.JDK;
private URL sslTruststore;
private String sslTruststorePassword;
private URL sslKeystore;
private String sslKeystorePassword;
private String[] sslProtocols;
private String[] sslCiphers;
private TrustManagerFactory sslTrustManagerFactory;
private KeyManagerFactory sslKeyManagerFactory;
private int pingConnectionInterval = 30000;
private boolean keepAlive;
private int tcpKeepAliveCount;
private int tcpKeepAliveIdle;
private int tcpKeepAliveInterval;
private int tcpUserTimeout;
private boolean tcpNoDelay = true;
private NameMapper nameMapper = NameMapper.direct();
private CommandMapper commandMapper = CommandMapper.direct();
BaseConfig() {
}
BaseConfig(T config) {
setPassword(config.getPassword());
setUsername(config.getUsername());
setSubscriptionsPerConnection(config.getSubscriptionsPerConnection());
setRetryAttempts(config.getRetryAttempts());
setRetryInterval(config.getRetryInterval());
setTimeout(config.getTimeout());
setClientName(config.getClientName());
setConnectTimeout(config.getConnectTimeout());
setIdleConnectionTimeout(config.getIdleConnectionTimeout());
setSslEnableEndpointIdentification(config.isSslEnableEndpointIdentification());
setSslProvider(config.getSslProvider());
setSslTruststore(config.getSslTruststore());
setSslTruststorePassword(config.getSslTruststorePassword());
setSslKeystoreType(config.getSslKeystoreType());
setSslKeystore(config.getSslKeystore());
setSslKeystorePassword(config.getSslKeystorePassword());
setSslProtocols(config.getSslProtocols());
setSslCiphers(config.getSslCiphers());
setSslKeyManagerFactory(config.getSslKeyManagerFactory());
setSslTrustManagerFactory(config.getSslTrustManagerFactory());
setPingConnectionInterval(config.getPingConnectionInterval());
setKeepAlive(config.isKeepAlive());
setTcpKeepAliveCount(config.getTcpKeepAliveCount());
setTcpKeepAliveIdle(config.getTcpKeepAliveIdle());
setTcpKeepAliveInterval(config.getTcpKeepAliveInterval());
setTcpUserTimeout(config.getTcpUserTimeout());
setTcpNoDelay(config.isTcpNoDelay());
setNameMapper(config.getNameMapper());
setCredentialsResolver(config.getCredentialsResolver());
setCommandMapper(config.getCommandMapper());
setSslVerificationMode(config.getSslVerificationMode());
setSubscriptionTimeout(config.getSubscriptionTimeout());
}
/**
* Subscriptions per Redis connection limit
*
* Default is 5
*
* @param subscriptionsPerConnection amount
* @return config
*/
public T setSubscriptionsPerConnection(int subscriptionsPerConnection) {
this.subscriptionsPerConnection = subscriptionsPerConnection;
return (T) this;
}
public int getSubscriptionsPerConnection() {
return subscriptionsPerConnection;
}
/**
* Password for Redis authentication. Should be null if not needed.
*
* Default is null
*
* @param password for connection
* @return config
*/
public T setPassword(String password) {
this.password = password;
return (T) this;
}
public String getPassword() {
return password;
}
/**
* Username for Redis authentication. Should be null if not needed
*
* Default is null
*
* Requires Redis 6.0+
*
* @param username for connection
* @return config
*/
public T setUsername(String username) {
this.username = username;
return (T) this;
}
public String getUsername() {
return username;
}
/**
* Error will be thrown if Redis command can't be sent to Redis server after retryAttempts
.
* But if it sent successfully then timeout
will be started.
*
* Default is 3
attempts
*
* @see #timeout
* @param retryAttempts retry attempts
* @return config
*/
public T setRetryAttempts(int retryAttempts) {
this.retryAttempts = retryAttempts;
return (T) this;
}
public int getRetryAttempts() {
return retryAttempts;
}
/**
* Defines time interval for another one attempt send Redis command
* if it hasn't been sent already.
*
* Default is 1500
milliseconds
*
* @param retryInterval - time in milliseconds
* @return config
*/
public T setRetryInterval(int retryInterval) {
this.retryInterval = retryInterval;
return (T) this;
}
public int getRetryInterval() {
return retryInterval;
}
/**
* Redis server response timeout. Starts to countdown when Redis command has been successfully sent.
*
* Default is 3000
milliseconds
*
* @param timeout in milliseconds
* @return config
*/
public T setTimeout(int timeout) {
this.timeout = timeout;
return (T) this;
}
public int getTimeout() {
return timeout;
}
public int getSubscriptionTimeout() {
return subscriptionTimeout;
}
/**
* Defines subscription timeout applied per channel subscription.
*
* Default is 7500
milliseconds.
*
* @param subscriptionTimeout timeout in milliseconds
* @return config
*/
public T setSubscriptionTimeout(int subscriptionTimeout) {
this.subscriptionTimeout = subscriptionTimeout;
return (T) this;
}
/**
* Setup connection name during connection init
* via CLIENT SETNAME command
*
* Default is null
*
* @param clientName name of client
* @return config
*/
public T setClientName(String clientName) {
this.clientName = clientName;
return (T) this;
}
public String getClientName() {
return clientName;
}
/**
* Timeout during connecting to any Redis server.
*
* Default is 10000
milliseconds.
*
* @param connectTimeout timeout in milliseconds
* @return config
*/
public T setConnectTimeout(int connectTimeout) {
this.connectTimeout = connectTimeout;
return (T) this;
}
public int getConnectTimeout() {
return connectTimeout;
}
/**
* If pooled connection not used for a timeout
time
* and current connections amount bigger than minimum idle connections pool size,
* then it will closed and removed from pool.
*
* Default is 10000
milliseconds.
*
* @param idleConnectionTimeout timeout in milliseconds
* @return config
*/
public T setIdleConnectionTimeout(int idleConnectionTimeout) {
this.idleConnectionTimeout = idleConnectionTimeout;
return (T) this;
}
public int getIdleConnectionTimeout() {
return idleConnectionTimeout;
}
@Deprecated
public boolean isSslEnableEndpointIdentification() {
return this.sslVerificationMode == SslVerificationMode.STRICT;
}
/**
* Use {@link #setSslVerificationMode(SslVerificationMode)} instead.
*
* @param sslEnableEndpointIdentification boolean value
* @return config
*/
@Deprecated
public T setSslEnableEndpointIdentification(boolean sslEnableEndpointIdentification) {
if (sslEnableEndpointIdentification) {
this.sslVerificationMode = SslVerificationMode.STRICT;
} else {
this.sslVerificationMode = SslVerificationMode.NONE;
}
return (T) this;
}
public SslProvider getSslProvider() {
return sslProvider;
}
/**
* Defines SSL provider used to handle SSL connections.
*
* Default is JDK
*
* @param sslProvider ssl provider
* @return config
*/
public T setSslProvider(SslProvider sslProvider) {
this.sslProvider = sslProvider;
return (T) this;
}
public URL getSslTruststore() {
return sslTruststore;
}
/**
* Defines path to SSL truststore
*
* Default is null
*
* @param sslTruststore truststore path
* @return config
*/
public T setSslTruststore(URL sslTruststore) {
this.sslTruststore = sslTruststore;
return (T) this;
}
public String getSslTruststorePassword() {
return sslTruststorePassword;
}
/**
* Defines password for SSL truststore.
* SSL truststore is read on each new connection creation and can be dynamically reloaded.
*
* Default is null
*
* @param sslTruststorePassword - password
* @return config
*/
public T setSslTruststorePassword(String sslTruststorePassword) {
this.sslTruststorePassword = sslTruststorePassword;
return (T) this;
}
public URL getSslKeystore() {
return sslKeystore;
}
/**
* Defines path to SSL keystore.
* SSL keystore is read on each new connection creation and can be dynamically reloaded.
*
* Default is null
*
* @param sslKeystore path to keystore
* @return config
*/
public T setSslKeystore(URL sslKeystore) {
this.sslKeystore = sslKeystore;
return (T) this;
}
public String getSslKeystorePassword() {
return sslKeystorePassword;
}
/**
* Defines password for SSL keystore
*
* Default is null
*
* @param sslKeystorePassword password
* @return config
*/
public T setSslKeystorePassword(String sslKeystorePassword) {
this.sslKeystorePassword = sslKeystorePassword;
return (T) this;
}
public String[] getSslProtocols() {
return sslProtocols;
}
/**
* Defines SSL protocols.
* Example values: TLSv1.3, TLSv1.2, TLSv1.1, TLSv1
*
* Default is null
*
* @param sslProtocols protocols
* @return config
*/
public T setSslProtocols(String[] sslProtocols) {
this.sslProtocols = sslProtocols;
return (T) this;
}
public int getPingConnectionInterval() {
return pingConnectionInterval;
}
/**
* Defines PING command sending interval per connection to Redis.
* 0
means disable.
*
* Default is 30000
*
* @param pingConnectionInterval time in milliseconds
* @return config
*/
public T setPingConnectionInterval(int pingConnectionInterval) {
this.pingConnectionInterval = pingConnectionInterval;
return (T) this;
}
public boolean isKeepAlive() {
return keepAlive;
}
/**
* Enables TCP keepAlive for connection
*
* Default is false
*
* @param keepAlive boolean value
* @return config
*/
public T setKeepAlive(boolean keepAlive) {
this.keepAlive = keepAlive;
return (T) this;
}
public int getTcpKeepAliveCount() {
return tcpKeepAliveCount;
}
/**
* Defines the maximum number of keepalive probes
* TCP should send before dropping the connection.
*
* @param tcpKeepAliveCount maximum number of keepalive probes
* @return config
*/
public T setTcpKeepAliveCount(int tcpKeepAliveCount) {
this.tcpKeepAliveCount = tcpKeepAliveCount;
return (T) this;
}
public int getTcpKeepAliveIdle() {
return tcpKeepAliveIdle;
}
/**
* Defines the time in seconds the connection needs to remain idle
* before TCP starts sending keepalive probes,
*
* @param tcpKeepAliveIdle time in seconds
* @return config
*/
public T setTcpKeepAliveIdle(int tcpKeepAliveIdle) {
this.tcpKeepAliveIdle = tcpKeepAliveIdle;
return (T) this;
}
public int getTcpKeepAliveInterval() {
return tcpKeepAliveInterval;
}
/**
* Defines the time in seconds between individual keepalive probes.
*
* @param tcpKeepAliveInterval time in seconds
* @return config
*/
public T setTcpKeepAliveInterval(int tcpKeepAliveInterval) {
this.tcpKeepAliveInterval = tcpKeepAliveInterval;
return (T) this;
}
public int getTcpUserTimeout() {
return tcpUserTimeout;
}
/**
* Defines the maximum amount of time in milliseconds that transmitted data may
* remain unacknowledged, or buffered data may remain untransmitted
* (due to zero window size) before TCP will forcibly close the connection.
*
* @param tcpUserTimeout time in milliseconds
* @return config
*/
public T setTcpUserTimeout(int tcpUserTimeout) {
this.tcpUserTimeout = tcpUserTimeout;
return (T) this;
}
public boolean isTcpNoDelay() {
return tcpNoDelay;
}
/**
* Enables TCP noDelay for connection
*
* Default is true
*
* @param tcpNoDelay boolean value
* @return config
*/
public T setTcpNoDelay(boolean tcpNoDelay) {
this.tcpNoDelay = tcpNoDelay;
return (T) this;
}
public NameMapper getNameMapper() {
return nameMapper;
}
/**
* Defines Name mapper which maps Redisson object name.
* Applied to all Redisson objects.
*
* @param nameMapper name mapper object
* @return config
*/
public T setNameMapper(NameMapper nameMapper) {
this.nameMapper = nameMapper;
return (T) this;
}
public CredentialsResolver getCredentialsResolver() {
return credentialsResolver;
}
/**
* Defines Credentials resolver which is invoked during connection for Redis server authentication.
* It makes possible to specify dynamically changing Redis credentials.
*
* @param credentialsResolver Credentials resolver object
* @return config
*/
public T setCredentialsResolver(CredentialsResolver credentialsResolver) {
this.credentialsResolver = credentialsResolver;
return (T) this;
}
public String getSslKeystoreType() {
return sslKeystoreType;
}
/**
* Defines SSL keystore type.
*
* Default is null
*
* @param sslKeystoreType keystore type
* @return config
*/
public T setSslKeystoreType(String sslKeystoreType) {
this.sslKeystoreType = sslKeystoreType;
return (T) this;
}
public String[] getSslCiphers() {
return sslCiphers;
}
/**
* Defines SSL ciphers.
*
* Default is null
*
* @param sslCiphers ciphers
* @return config
*/
public T setSslCiphers(String[] sslCiphers) {
this.sslCiphers = sslCiphers;
return (T) this;
}
public TrustManagerFactory getSslTrustManagerFactory() {
return sslTrustManagerFactory;
}
/**
* Defines SSL TrustManagerFactory.
*
* Default is null
*
* @param trustManagerFactory trust manager value
* @return config
*/
public T setSslTrustManagerFactory(TrustManagerFactory trustManagerFactory) {
this.sslTrustManagerFactory = trustManagerFactory;
return (T) this;
}
public KeyManagerFactory getSslKeyManagerFactory() {
return sslKeyManagerFactory;
}
/**
* Defines SSL KeyManagerFactory.
*
* Default is null
*
* @param keyManagerFactory key manager value
* @return config
*/
public BaseConfig setSslKeyManagerFactory(KeyManagerFactory keyManagerFactory) {
this.sslKeyManagerFactory = keyManagerFactory;
return this;
}
public CommandMapper getCommandMapper() {
return commandMapper;
}
/**
* Defines Command mapper which maps Redis command name.
* Applied to all Redis commands.
*
* @param commandMapper Redis command name mapper object
* @return config
*/
public T setCommandMapper(CommandMapper commandMapper) {
this.commandMapper = commandMapper;
return (T) this;
}
public SslVerificationMode getSslVerificationMode() {
return sslVerificationMode;
}
/**
* Defines SSL verification mode, which prevents man-in-the-middle attacks.
*
*
* Default is SslVerificationMode.STRICT
*
* @param sslVerificationMode
* @return
*/
public T setSslVerificationMode(SslVerificationMode sslVerificationMode) {
this.sslVerificationMode = sslVerificationMode;
return (T) this;
}
}