Class LocalizedQueueConnectionFactory
java.lang.Object
org.springframework.amqp.rabbit.connection.LocalizedQueueConnectionFactory
- All Implemented Interfaces:
- ConnectionFactory,- RoutingConnectionFactory,- DisposableBean,- Lifecycle,- Phased,- SmartLifecycle
public class LocalizedQueueConnectionFactory
extends Object
implements ConnectionFactory, RoutingConnectionFactory, DisposableBean, SmartLifecycle
A 
RoutingConnectionFactory that determines the node on which a queue is located and
 returns a factory that connects directly to that node.
 The RabbitMQ management plugin is called over REST to determine the node and the corresponding
 address for that node is injected into the connection factory.
 A single instance of each connection factory is retained in a cache.
 If the location cannot be determined, the default connection factory is returned. This connection
 factory is typically configured to connect to all the servers in a fail-over mode.
 getTargetConnectionFactory(Object) is invoked by the
 SimpleMessageListenerContainer, when establishing a connection, with the lookup key having
 the format '[queueName]'.
 
All ConnectionFactory methods delegate to the default
- Since:
- 1.2
- Author:
- Gary Russell, Christian Tzolov, Ngoc Nhan
- 
Field SummaryFields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
- 
Constructor SummaryConstructorsConstructorDescriptionLocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, String[] addresses, String[] adminUris, String[] nodes, String vhost, String username, String password, boolean useSSL, String keyStore, String trustStore, String keyStorePassPhrase, String trustStorePassPhrase) LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, String[] addresses, String[] adminUris, String[] nodes, String vhost, String username, String password, boolean useSSL, Resource sslPropertiesLocation) LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, Map<String, String> nodeToAddress, String[] adminUris, String vhost, String username, String password, boolean useSSL, String keyStore, String trustStore, String keyStorePassPhrase, String trustStorePassPhrase) LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, Map<String, String> nodeToAddress, String[] adminUris, String vhost, String username, String password, boolean useSSL, Resource sslPropertiesLocation) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddConnectionListener(ConnectionListener listener) voidprotected ConnectionFactorycreateConnectionFactory(String address, String node) Create a dedicated connection factory for the address.voiddestroy()getHost()intgetPhase()intgetPort()Returns theConnectionFactorybound to given lookup key, or null if one does not exist.booleanbooleanremoveConnectionListener(ConnectionListener listener) voidClose any connection(s) that might be cached by this factory.voidsetNodeLocator(NodeLocator<?> nodeLocator) Set aNodeLocatorto use to find the node address for the leader.voidstart()voidstop()Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.amqp.rabbit.connection.ConnectionFactorygetPublisherConnectionFactory, isPublisherConfirms, isPublisherReturns, isSimplePublisherConfirmsMethods inherited from interface org.springframework.context.SmartLifecycleisAutoStartup, stop
- 
Constructor Details- 
LocalizedQueueConnectionFactorypublic LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, Map<String, String> nodeToAddress, String[] adminUris, String vhost, String username, String password, boolean useSSL, Resource sslPropertiesLocation) - Parameters:
- defaultConnectionFactory- the fallback connection factory to use if the queue can't be located.
- nodeToAddress- a Map of node to address: (rabbit@server1 : server1:5672)
- adminUris- the rabbitmq admin addresses (https://host:port, ...) must be the same length as addresses.
- vhost- the virtual host.
- username- the user name.
- password- the password.
- useSSL- use SSL.
- sslPropertiesLocation- the SSL properties location.
 
- 
LocalizedQueueConnectionFactorypublic LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, Map<String, String> nodeToAddress, String[] adminUris, String vhost, String username, String password, boolean useSSL, String keyStore, String trustStore, String keyStorePassPhrase, String trustStorePassPhrase) - Parameters:
- defaultConnectionFactory- the fallback connection factory to use if the queue can't be located.
- nodeToAddress- a Map of node to address: (rabbit@server1 : server1:5672)
- adminUris- the rabbitmq admin addresses (https://host:port, ...) must be the same length as addresses.
- vhost- the virtual host.
- username- the user name.
- password- the password.
- useSSL- use SSL.
- keyStore- the key store resource (e.g. "file:/foo/keystore").
- trustStore- the trust store resource (e.g. "file:/foo/truststore").
- keyStorePassPhrase- the pass phrase for the key store.
- trustStorePassPhrase- the pass phrase for the trust store.
 
- 
LocalizedQueueConnectionFactorypublic LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, String[] addresses, String[] adminUris, String[] nodes, String vhost, String username, String password, boolean useSSL, @Nullable Resource sslPropertiesLocation) - Parameters:
- defaultConnectionFactory- the fallback connection factory to use if the queue can't be located.
- addresses- the rabbitmq server addresses (host:port, ...).
- adminUris- the rabbitmq admin addresses (https://host:port, ...)
- nodes- the rabbitmq nodes corresponding to addresses (rabbit@server1, ...) must be the same length as addresses.
- vhost- the virtual host.
- username- the user name.
- password- the password.
- useSSL- use SSL.
- sslPropertiesLocation- the SSL properties location.
 
- 
LocalizedQueueConnectionFactorypublic LocalizedQueueConnectionFactory(ConnectionFactory defaultConnectionFactory, String[] addresses, String[] adminUris, String[] nodes, String vhost, String username, String password, boolean useSSL, String keyStore, String trustStore, String keyStorePassPhrase, String trustStorePassPhrase) - Parameters:
- defaultConnectionFactory- the fallback connection factory to use if the queue can't be located.
- addresses- the rabbitmq server addresses (host:port, ...).
- adminUris- the rabbitmq admin addresses (https://host:port, ...).
- nodes- the rabbitmq nodes corresponding to addresses (rabbit@server1, ...) must be the same length as addresses.
- vhost- the virtual host.
- username- the user name.
- password- the password.
- useSSL- use SSL.
- keyStore- the key store resource (e.g. "file:/foo/keystore").
- trustStore- the trust store resource (e.g. "file:/foo/truststore").
- keyStorePassPhrase- the pass phrase for the key store.
- trustStorePassPhrase- the pass phrase for the trust store.
 
 
- 
- 
Method Details- 
setNodeLocatorSet aNodeLocatorto use to find the node address for the leader.- Parameters:
- nodeLocator- the locator.
- Since:
- 2.4.8
 
- 
createConnection- Specified by:
- createConnectionin interface- ConnectionFactory
- Throws:
- AmqpException
 
- 
getHost- Specified by:
- getHostin interface- ConnectionFactory
 
- 
getPortpublic int getPort()- Specified by:
- getPortin interface- ConnectionFactory
 
- 
getVirtualHost- Specified by:
- getVirtualHostin interface- ConnectionFactory
 
- 
getUsername- Specified by:
- getUsernamein interface- ConnectionFactory
 
- 
getPhasepublic int getPhase()- Specified by:
- getPhasein interface- Phased
- Specified by:
- getPhasein interface- SmartLifecycle
 
- 
start
- 
stop
- 
isRunning
- 
addConnectionListener- Specified by:
- addConnectionListenerin interface- ConnectionFactory
 
- 
removeConnectionListener- Specified by:
- removeConnectionListenerin interface- ConnectionFactory
 
- 
clearConnectionListenerspublic void clearConnectionListeners()- Specified by:
- clearConnectionListenersin interface- ConnectionFactory
 
- 
getTargetConnectionFactoryDescription copied from interface:RoutingConnectionFactoryReturns theConnectionFactorybound to given lookup key, or null if one does not exist.- Specified by:
- getTargetConnectionFactoryin interface- RoutingConnectionFactory
- Parameters:
- key- The lookup key to which the- ConnectionFactoryis bound
- Returns:
- the ConnectionFactorybound to the given lookup key, or null if one does not exist
 
- 
createConnectionFactoryCreate a dedicated connection factory for the address.- Parameters:
- address- the address to which the factory should connect.
- node- the node.
- Returns:
- the connection factory.
 
- 
resetConnectionpublic void resetConnection()Description copied from interface:ConnectionFactoryClose any connection(s) that might be cached by this factory. This does not prevent new connections from being opened.- Specified by:
- resetConnectionin interface- ConnectionFactory
 
- 
destroypublic void destroy()- Specified by:
- destroyin interface- DisposableBean
 
 
-