Class RabbitConnectionFactoryBean
java.lang.Object
org.springframework.beans.factory.config.AbstractFactoryBean<com.rabbitmq.client.ConnectionFactory>
org.springframework.amqp.rabbit.connection.RabbitConnectionFactoryBean
- All Implemented Interfaces:
- Aware,- BeanClassLoaderAware,- BeanFactoryAware,- DisposableBean,- FactoryBean<com.rabbitmq.client.ConnectionFactory>,- InitializingBean
public class RabbitConnectionFactoryBean
extends AbstractFactoryBean<com.rabbitmq.client.ConnectionFactory>
Factory bean to create a RabbitMQ ConnectionFactory, delegating most setter methods and
 optionally enabling SSL, with or without certificate validation. When
 
sslPropertiesLocation is not null, the
 default implementation loads a PKCS12 keystore and a JKS truststore
 using the supplied properties and intializes key and trust manager factories, using
 algorithm SunX509 by default. These are then used to initialize an
 SSLContext using the sslAlgorithm (default
 TLSv1.2, falling back to TLSv1.1, if 1.2 is not available).
 
 Override createSSLContext() to create and/or perform further modification of
 the context.
 
 Override setUpSSL() to take complete control over setting up SSL.
- Since:
- 1.4
- Author:
- Gary Russell, Heath Abelson, Arnaud Cogoluègnes, Hareendran, Dominique Villard, Zachary DeLuca
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final com.rabbitmq.client.ConnectionFactoryFields inherited from class org.springframework.beans.factory.config.AbstractFactoryBeanloggerFields inherited from interface org.springframework.beans.factory.FactoryBeanOBJECT_TYPE_ATTRIBUTE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidprotected KeyManager[]protected TrustManager[]protected com.rabbitmq.client.ConnectionFactoryprotected SSLContextOverride this method to create and/or configure theSSLContextused by theConnectionFactory.protected Stringprotected Stringprotected Stringprotected Resourceprotected StringGet the key store type - this defaults to PKCS12 if not overridden bysetSslPropertiesLocation(Resource)orsetKeyStoreType(java.lang.String).Class<?>com.rabbitmq.client.ConnectionFactoryAccess the connection factory to set any other properties not supported by this factory bean.protected ResourceLoaderGet the resource loader; used to resolve the key store and trust storeResources to input streams.protected SecureRandomprotected Stringprotected Resourceprotected Stringprotected Stringprotected Stringprotected Resourceprotected StringGet the trust store type - this defaults to JKS if not overridden bysetSslPropertiesLocation(Resource)orsetTrustStoreType(java.lang.String).booleanWhether or not Server Side certificate has to be validated or not.protected booleanisUseSSL()voidsetAutomaticRecoveryEnabled(boolean automaticRecoveryEnabled) Set to true to enable amqp-client automatic recovery.voidsetChannelRpcTimeout(int channelRpcTimeout) voidsetClientProperties(Map<String, Object> clientProperties) Add custom client properties.voidsetConnectionTimeout(int connectionTimeout) voidsetCredentialsProvider(com.rabbitmq.client.impl.CredentialsProvider provider) Set a credentials provider (e.g.voidsetCredentialsRefreshService(com.rabbitmq.client.impl.CredentialsRefreshService service) Set a refresh service.voidsetEnableHostnameVerification(boolean enable) Enable server hostname verification for TLS connections.voidsetExceptionHandler(com.rabbitmq.client.ExceptionHandler exceptionHandler) voidvoidsetKeyStore(String keyStore) Set the key store resource (e.g.voidsetKeyStoreAlgorithm(String keyStoreAlgorithm) Set the algorithm used when creating the key store, defaultSunX509.voidsetKeyStorePassphrase(String keyStorePassphrase) Set the key store pass phrase - overrides the property insetSslPropertiesLocation(Resource).voidsetKeyStoreResource(Resource keyStoreResource) Set a Resource pointing to the key store.voidsetKeyStoreType(String keyStoreType) Set the key store type - overrides the property insetSslPropertiesLocation(Resource).voidsetMaxInboundMessageBodySize(int maxInboundMessageBodySize) Set the maximum body size of inbound (received) messages in bytes.voidsetMetricsCollector(com.rabbitmq.client.MetricsCollector metricsCollector) voidsetNioParams(com.rabbitmq.client.impl.nio.NioParams nioParams) voidsetPassword(String password) voidsetPort(int port) voidsetRequestedChannelMax(int requestedChannelMax) voidsetRequestedFrameMax(int requestedFrameMax) voidsetRequestedHeartbeat(int requestedHeartbeat) voidsetResourceLoader(ResourceLoader resourceLoader) Set the resource loader; used to resolve the key store and trust storeResources to input streams.voidsetSaslConfig(com.rabbitmq.client.SaslConfig saslConfig) voidsetSecureRandom(SecureRandom secureRandom) Set the secure random to use when initializing theSSLContext.voidsetSharedExecutor(ExecutorService executor) voidsetSkipServerCertificateValidation(boolean skipServerCertificateValidation) Whether or not Server Side certificate has to be validated or not.voidsetSocketConfigurator(com.rabbitmq.client.SocketConfigurator socketConfigurator) voidsetSocketFactory(SocketFactory factory) voidsetSslAlgorithm(String sslAlgorithm) Set the algorithm to use; default TLSv1.1.voidsetSslPropertiesLocation(Resource sslPropertiesLocation) WhensetUseSSL(boolean)is true, the SSL properties to use (optional).voidsetThreadFactory(ThreadFactory threadFactory) voidsetTopologyRecoveryEnabled(boolean topologyRecoveryEnabled) Set to true to enable amqp-client topology recovery.voidsetTrustStore(String trustStore) Set the key store resource (e.g.voidsetTrustStoreAlgorithm(String trustStoreAlgorithm) Set the algorithm used when creating the trust store, defaultSunX509.voidsetTrustStorePassphrase(String trustStorePassphrase) Set the trust store pass phrase - overrides the property insetSslPropertiesLocation(Resource).voidsetTrustStoreResource(Resource trustStoreResource) Set a Resource pointing to the trust store.voidsetTrustStoreType(String trustStoreType) Set the trust store type - overrides the property insetSslPropertiesLocation(Resource).protected voidsetUpSSL()Override this method to take complete control over the SSL setup.voidvoidvoidsetUseNio(boolean useNio) Whether or not the factory should be configured to use Java NIO.voidsetUsername(String username) voidsetUseSSL(boolean useSSL) Whether or not the factory should be configured to use SSL.voidsetVirtualHost(String virtualHost) Methods inherited from class org.springframework.beans.factory.config.AbstractFactoryBeandestroy, destroyInstance, getBeanFactory, getBeanTypeConverter, getEarlySingletonInterfaces, getObject, isSingleton, setBeanClassLoader, setBeanFactory, setSingleton
- 
Field Details- 
connectionFactoryprotected final com.rabbitmq.client.ConnectionFactory connectionFactory
 
- 
- 
Constructor Details- 
RabbitConnectionFactoryBeanpublic RabbitConnectionFactoryBean()
 
- 
- 
Method Details- 
isSkipServerCertificateValidationpublic boolean isSkipServerCertificateValidation()Whether or not Server Side certificate has to be validated or not.- Returns:
- true if Server Side certificate has to be skipped
- Since:
- 1.6.6
 
- 
setSkipServerCertificateValidationpublic void setSkipServerCertificateValidation(boolean skipServerCertificateValidation) Whether or not Server Side certificate has to be validated or not. This would be used if useSSL is set to true and should only be used on dev or Qa regions skipServerCertificateValidation should never be set to true in production- Parameters:
- skipServerCertificateValidation- Flag to override Server side certificate checks; if set to- true- TrustEverythingTrustManagerwould be used.
- Since:
- 1.6.6
- See Also:
- 
- TrustEverythingTrustManager
 
 
- 
setUseSSLpublic void setUseSSL(boolean useSSL) Whether or not the factory should be configured to use SSL.- Parameters:
- useSSL- true to use SSL.
 
- 
isUseSSLprotected boolean isUseSSL()- Returns:
- true to use ssl.
- Since:
- 1.4.4.
 
- 
setSslAlgorithmSet the algorithm to use; default TLSv1.1.- Parameters:
- sslAlgorithm- the algorithm.
 
- 
getSslAlgorithm- Returns:
- the ssl algorithm.
- Since:
- 1.4.4
 
- 
setSslPropertiesLocationWhensetUseSSL(boolean)is true, the SSL properties to use (optional). Resource referencing a properties file with the following properties:- keyStore=file:/secret/keycert.p12
- trustStore=file:/secret/trustStore
- keyStore.passPhrase=secret
- trustStore.passPhrase=secret
 If this is provided, its properties (if present) will override the explicitly set property in this bean. - Parameters:
- sslPropertiesLocation- the Resource to the ssl properties
 
- 
getSslPropertiesLocation- Returns:
- the properties location.
- Since:
- 1.4.4
 
- 
getKeyStore- Returns:
- the key store resource.
- Since:
- 1.5
 
- 
setKeyStoreSet the key store resource (e.g. file:/foo/keystore) - overrides the property insetSslPropertiesLocation(Resource). Ignored ifsetTrustStoreResource(Resource)is called with a resource.- Parameters:
- keyStore- the keystore resource.
- Since:
- 1.5
 
- 
getKeyStoreResource
- 
setKeyStoreResourceSet a Resource pointing to the key store.- Parameters:
- keyStoreResource- the resource.
- Since:
- 1.6.4
 
- 
getTrustStore- Returns:
- the trust store resource.
- Since:
- 1.5
 
- 
setTrustStoreSet the key store resource (e.g. file:/foo/truststore) - overrides the property insetSslPropertiesLocation(Resource). Ignored ifsetTrustStoreResource(Resource)is called with a resource.- Parameters:
- trustStore- the truststore resource.
- Since:
- 1.5
 
- 
getTrustStoreResource
- 
setTrustStoreResourceSet a Resource pointing to the trust store.- Parameters:
- trustStoreResource- the resource.
- Since:
- 1.6.4
 
- 
getKeyStorePassphrase- Returns:
- the key store pass phrase.
- Since:
- 1.5
 
- 
setKeyStorePassphraseSet the key store pass phrase - overrides the property insetSslPropertiesLocation(Resource).- Parameters:
- keyStorePassphrase- the key store pass phrase.
- Since:
- 1.5
 
- 
getTrustStorePassphrase- Returns:
- the trust store pass phrase.
- Since:
- 1.5
 
- 
setTrustStorePassphraseSet the trust store pass phrase - overrides the property insetSslPropertiesLocation(Resource).- Parameters:
- trustStorePassphrase- the trust store pass phrase.
- Since:
- 1.5
 
- 
getKeyStoreTypeGet the key store type - this defaults to PKCS12 if not overridden bysetSslPropertiesLocation(Resource)orsetKeyStoreType(java.lang.String).- Returns:
- the key store type.
- Since:
- 1.6.2
 
- 
setKeyStoreTypeSet the key store type - overrides the property insetSslPropertiesLocation(Resource).- Parameters:
- keyStoreType- the key store type.
- Since:
- 1.6.2
- See Also:
 
- 
getTrustStoreTypeGet the trust store type - this defaults to JKS if not overridden bysetSslPropertiesLocation(Resource)orsetTrustStoreType(java.lang.String).- Returns:
- the trust store type.
- Since:
- 1.6.2
 
- 
setTrustStoreTypeSet the trust store type - overrides the property insetSslPropertiesLocation(Resource).- Parameters:
- trustStoreType- the trust store type.
- Since:
- 1.6.2
- See Also:
 
- 
getSecureRandom
- 
setSecureRandomSet the secure random to use when initializing theSSLContext. Defaults to null, in which case the default implementation is used.- Parameters:
- secureRandom- the secure random.
- Since:
- 1.6.4
- See Also:
 
- 
setHost- Parameters:
- host- the host.
- See Also:
- 
- ConnectionFactory.setHost(java.lang.String)
 
 
- 
setPortpublic void setPort(int port) - Parameters:
- port- the port.
- See Also:
- 
- ConnectionFactory.setPort(int)
 
 
- 
setUsername- Parameters:
- username- the user name.
- See Also:
- 
- ConnectionFactory.setUsername(java.lang.String)
 
 
- 
setPassword- Parameters:
- password- the password.
- See Also:
- 
- ConnectionFactory.setPassword(java.lang.String)
 
 
- 
setCredentialsProviderpublic void setCredentialsProvider(com.rabbitmq.client.impl.CredentialsProvider provider) Set a credentials provider (e.g. OAUTH2).- Parameters:
- provider- the provider.
- Since:
- 2.3
 
- 
setCredentialsRefreshServicepublic void setCredentialsRefreshService(com.rabbitmq.client.impl.CredentialsRefreshService service) Set a refresh service.- Parameters:
- service- the service.
- Since:
- 2.3
 
- 
setVirtualHost- Parameters:
- virtualHost- the virtual host.
- See Also:
- 
- ConnectionFactory.setVirtualHost(java.lang.String)
 
 
- 
setUri- Parameters:
- uri- the uri.
- See Also:
- 
- ConnectionFactory.setUri(java.net.URI)
 
 
- 
setUri- Parameters:
- uriString- the uri.
- See Also:
- 
- ConnectionFactory.setUri(java.lang.String)
 
 
- 
setRequestedChannelMaxpublic void setRequestedChannelMax(int requestedChannelMax) - Parameters:
- requestedChannelMax- the max requested channels.
- See Also:
- 
- ConnectionFactory.setRequestedChannelMax(int)
 
 
- 
setRequestedFrameMaxpublic void setRequestedFrameMax(int requestedFrameMax) - Parameters:
- requestedFrameMax- the requested max frames.
- See Also:
- 
- ConnectionFactory.setRequestedFrameMax(int)
 
 
- 
setConnectionTimeoutpublic void setConnectionTimeout(int connectionTimeout) - Parameters:
- connectionTimeout- the connection timeout.
- See Also:
- 
- ConnectionFactory.setConnectionTimeout(int)
 
 
- 
setRequestedHeartbeatpublic void setRequestedHeartbeat(int requestedHeartbeat) - Parameters:
- requestedHeartbeat- the requested heartbeat.
- See Also:
- 
- ConnectionFactory.setRequestedHeartbeat(int)
 
 
- 
setClientPropertiesAdd custom client properties.- Parameters:
- clientProperties- the client properties.
- See Also:
- 
- ConnectionFactory.setClientProperties(java.util.Map)
 
 
- 
setSaslConfigpublic void setSaslConfig(com.rabbitmq.client.SaslConfig saslConfig) - Parameters:
- saslConfig- the sasl config.
- See Also:
- 
- ConnectionFactory.setSaslConfig(com.rabbitmq.client.SaslConfig)
 
 
- 
setSocketFactory- Parameters:
- factory- the socket factory.
- See Also:
- 
- ConnectionFactory.setSocketFactory(javax.net.SocketFactory)
 
 
- 
setSocketConfiguratorpublic void setSocketConfigurator(com.rabbitmq.client.SocketConfigurator socketConfigurator) - Parameters:
- socketConfigurator- the socket configurator.
- See Also:
- 
- ConnectionFactory.setSocketConfigurator(com.rabbitmq.client.SocketConfigurator)
 
 
- 
setThreadFactory- Parameters:
- threadFactory- the thread factory.
- See Also:
- 
- ConnectionFactory.setThreadFactory(java.util.concurrent.ThreadFactory)
 
 
- 
setExceptionHandlerpublic void setExceptionHandler(com.rabbitmq.client.ExceptionHandler exceptionHandler) - Parameters:
- exceptionHandler- the exception handler.
- See Also:
- 
- ConnectionFactory.setExceptionHandler(com.rabbitmq.client.ExceptionHandler)
 
 
- 
setUseNiopublic void setUseNio(boolean useNio) Whether or not the factory should be configured to use Java NIO.- Parameters:
- useNio- true to use Java NIO, false to use blocking IO
- See Also:
- 
- ConnectionFactory.useNio()
 
 
- 
setNioParamspublic void setNioParams(com.rabbitmq.client.impl.nio.NioParams nioParams) - Parameters:
- nioParams- the NIO parameters
- See Also:
- 
- ConnectionFactory.setNioParams(com.rabbitmq.client.impl.nio.NioParams)
 
 
- 
setMetricsCollectorpublic void setMetricsCollector(com.rabbitmq.client.MetricsCollector metricsCollector) - Parameters:
- metricsCollector- the metrics collector instance
- See Also:
- 
- ConnectionFactory.setMetricsCollector(MetricsCollector)
 
 
- 
setAutomaticRecoveryEnabledpublic void setAutomaticRecoveryEnabled(boolean automaticRecoveryEnabled) Set to true to enable amqp-client automatic recovery. Note: Spring AMQP implements its own connection recovery and this is generally not needed.- Parameters:
- automaticRecoveryEnabled- true to enable.
- Since:
- 1.7.1
 
- 
setTopologyRecoveryEnabledpublic void setTopologyRecoveryEnabled(boolean topologyRecoveryEnabled) Set to true to enable amqp-client topology recovery. Note: if there is a Rabbit admin in the application context, Spring AMQP implements its own recovery and this is generally not needed.- Parameters:
- topologyRecoveryEnabled- true to enable.
- Since:
- 1.7.1
 
- 
setChannelRpcTimeoutpublic void setChannelRpcTimeout(int channelRpcTimeout) - Parameters:
- channelRpcTimeout- continuation timeout for RPC calls in channels
- Since:
- 2.0
- See Also:
- 
- ConnectionFactory.setChannelRpcTimeout(int)
 
 
- 
setEnableHostnameVerificationpublic void setEnableHostnameVerification(boolean enable) Enable server hostname verification for TLS connections.This enables hostname verification regardless of the IO mode used (blocking or non-blocking IO). This can be called typically after setting the SSLContextwith one of theuseSslProtocolmethods. Requires amqp-client 5.4.0 or later.- Parameters:
- enable- false to disable.
- Since:
- 2.0.6
- See Also:
- 
- ConnectionFactory.enableHostnameVerification()
 
 
- 
setMaxInboundMessageBodySizepublic void setMaxInboundMessageBodySize(int maxInboundMessageBodySize) Set the maximum body size of inbound (received) messages in bytes.- Parameters:
- maxInboundMessageBodySize- the maximum size.
- Since:
- 2.4.15
- See Also:
- 
- ConnectionFactory.setMaxInboundMessageBodySize(int)
 
 
- 
getKeyStoreAlgorithm
- 
setKeyStoreAlgorithmSet the algorithm used when creating the key store, defaultSunX509.- Parameters:
- keyStoreAlgorithm- the algorithm.
- Since:
- 2.1.6
 
- 
getTrustStoreAlgorithm
- 
setTrustStoreAlgorithmSet the algorithm used when creating the trust store, defaultSunX509.- Parameters:
- trustStoreAlgorithm- the algorithm.
- Since:
- 2.1.6
 
- 
getResourceLoaderGet the resource loader; used to resolve the key store and trust storeResources to input streams.- Returns:
- the resource loader.
- Since:
- 2.3
 
- 
setResourceLoaderSet the resource loader; used to resolve the key store and trust storeResources to input streams.- Parameters:
- resourceLoader- the resource loader.
- Since:
- 2.3
 
- 
getRabbitConnectionFactorypublic com.rabbitmq.client.ConnectionFactory getRabbitConnectionFactory()Access the connection factory to set any other properties not supported by this factory bean.- Returns:
- the connection factory.
- Since:
- 1.7.14
 
- 
afterPropertiesSetpublic void afterPropertiesSet()- Specified by:
- afterPropertiesSetin interface- InitializingBean
- Overrides:
- afterPropertiesSetin class- AbstractFactoryBean<com.rabbitmq.client.ConnectionFactory>
 
- 
getObjectType- Specified by:
- getObjectTypein interface- FactoryBean<com.rabbitmq.client.ConnectionFactory>
- Specified by:
- getObjectTypein class- AbstractFactoryBean<com.rabbitmq.client.ConnectionFactory>
 
- 
createInstanceprotected com.rabbitmq.client.ConnectionFactory createInstance()- Specified by:
- createInstancein class- AbstractFactoryBean<com.rabbitmq.client.ConnectionFactory>
 
- 
setUpSSLprotected void setUpSSL()Override this method to take complete control over the SSL setup.- Since:
- 1.4.4
 
- 
configureKeyManagers@Nullable protected KeyManager[] configureKeyManagers() throws KeyStoreException, IOException, NoSuchAlgorithmException, CertificateException, UnrecoverableKeyException
- 
configureTrustManagers@Nullable protected TrustManager[] configureTrustManagers() throws KeyStoreException, IOException, NoSuchAlgorithmException, CertificateException
- 
createSSLContextOverride this method to create and/or configure theSSLContextused by theConnectionFactory.- Returns:
- The SSLContext.
- Throws:
- NoSuchAlgorithmException- if the algorithm is not available.
- Since:
- 1.4.4
 
 
-