public class CachingClientConnectionFactory extends AbstractClientConnectionFactory implements DisposableBean
singleUse=true in order for the connection to be
 returned to the cache after use. Users should not subsequently set the underlying property to
 false, or cache starvation will result.DEFAULT_REPLY_TIMEOUT, lifecycleMonitorEXPRESSION_PARSER, logger| Constructor and Description | 
|---|
| CachingClientConnectionFactory(AbstractClientConnectionFactory target,
                              int poolSize)Construct a caching connection factory that delegates to the provided factory, with
 the provided pool size. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | destroy() | 
| void | enableManualListenerRegistration()Set whether to automatically (default) or manually add a  TcpListenerto the
 connections created by this factory. | 
| boolean | equals(Object o) | 
| void | forceClose(TcpConnection connection)Force close the connection and null the field if it's
 a shared connection. | 
| int | getActiveCount() | 
| int | getAllocatedCount() | 
| String | getComponentType()Subclasses may implement this method to provide component type information. | 
| Deserializer<?> | getDeserializer() | 
| String | getHost() | 
| int | getIdleCount() | 
| TcpMessageMapper | getMapper() | 
| int | getPoolSize() | 
| int | getPort() | 
| TcpSender | getSender() | 
| Serializer<?> | getSerializer() | 
| int | getSoLinger() | 
| int | getSoReceiveBufferSize() | 
| int | getSoSendBufferSize() | 
| int | getSoTimeout() | 
| int | getSoTrafficClass() | 
| int | hashCode() | 
| boolean | isLookupHost() | 
| boolean | isRunning() | 
| boolean | isSingleUse() | 
| boolean | isSoKeepAlive() | 
| boolean | isSoTcpNoDelay() | 
| TcpConnectionSupport | obtainConnection() | 
| void | registerListener(TcpListener listener)Delegate TCP Client Connection factories that are used to receive
 data need a Listener to send the messages to. | 
| void | registerSender(TcpSender sender)Registers a TcpSender; for server sockets, used to
 provide connection information so a sender can be used
 to reply to incoming messages. | 
| void | setComponentName(String componentName)Sets the name of this component. | 
| void | setConnectionWaitTimeout(int connectionWaitTimeout) | 
| void | setDeserializer(Deserializer<?> deserializer) | 
| void | setInterceptorFactoryChain(TcpConnectionInterceptorFactoryChain interceptorFactoryChain) | 
| void | setLookupHost(boolean lookupHost)If true, DNS reverse lookup is done on the remote ip address. | 
| void | setMapper(TcpMessageMapper mapper) | 
| void | setPoolSize(int poolSize) | 
| void | setSerializer(Serializer<?> serializer) | 
| void | setSingleUse(boolean singleUse)Ignored on this factory; connections are always cached in the pool. | 
| void | setSoKeepAlive(boolean soKeepAlive) | 
| void | setSoLinger(int soLinger) | 
| void | setSoReceiveBufferSize(int soReceiveBufferSize) | 
| void | setSoSendBufferSize(int soSendBufferSize) | 
| void | setSoTcpNoDelay(boolean soTcpNoDelay) | 
| void | setSoTimeout(int soTimeout) | 
| void | setSoTrafficClass(int soTrafficClass) | 
| void | setTaskExecutor(Executor taskExecutor) | 
| void | start() | 
| void | stop()Stops the server. | 
buildNewConnection, getConnection, getConnectionTest, getConnectTimeout, getTheConnection, initializeConnection, obtainNewConnection, obtainSharedConnection, setConnectionTest, setConnectTimeout, setTheConnectionaddConnection, checkActive, closeConnection, delayRead, doAccept, getApplicationEventPublisher, getDelayedReads, getLifecycleMonitor, getListener, getOpenConnectionIds, getReadDelay, getSenders, getSslHandshakeTimeout, getTaskExecutor, getTcpSocketSupport, harvestClosedConnections, isActive, onInit, processNioSelections, setActive, setApplicationEventPublisher, setHost, setLeaveOpen, setNioHarvestInterval, setPort, setReadDelay, setSocketAttributes, setSslHandshakeTimeout, setTcpSocketSupport, toString, unregisterSender, wrapConnectionafterPropertiesSet, extractTypeIfPossible, generateId, getApplicationContext, getApplicationContextId, getBeanDescription, getBeanFactory, getBeanName, getChannelResolver, getComponentName, getConversionService, getExpression, getIntegrationProperties, getIntegrationProperty, getMessageBuilderFactory, getTaskScheduler, isInitialized, setApplicationContext, setBeanFactory, setBeanName, setChannelResolver, setConversionService, setMessageBuilderFactory, setPrimaryExpression, setTaskSchedulerpublic CachingClientConnectionFactory(AbstractClientConnectionFactory target, int poolSize)
target - the target factory.poolSize - the number of connections to allow.public void setConnectionWaitTimeout(int connectionWaitTimeout)
connectionWaitTimeout - the new timeout.SimplePool.setWaitTimeout(long)public void setPoolSize(int poolSize)
poolSize - the new pool size.SimplePool.setPoolSize(int)public int getPoolSize()
SimplePool.getPoolSize()public int getIdleCount()
SimplePool.getIdleCount()public int getActiveCount()
SimplePool.getActiveCount()public int getAllocatedCount()
SimplePool.getAllocatedCount()public TcpConnectionSupport obtainConnection()
obtainConnection in class AbstractClientConnectionFactorypublic boolean isRunning()
isRunning in interface LifecycleisRunning in interface ManageableLifecycleisRunning in class AbstractConnectionFactorypublic void setComponentName(String componentName)
IntegrationObjectSupportsetComponentName in class IntegrationObjectSupportcomponentName - The component name.public String getComponentType()
IntegrationObjectSupportgetComponentType in interface NamedComponentgetComponentType in class IntegrationObjectSupportpublic int getSoTimeout()
getSoTimeout in class AbstractConnectionFactorypublic void setSoTimeout(int soTimeout)
setSoTimeout in class AbstractConnectionFactorysoTimeout - the soTimeout to setpublic int getSoReceiveBufferSize()
getSoReceiveBufferSize in class AbstractConnectionFactorypublic void setSoReceiveBufferSize(int soReceiveBufferSize)
setSoReceiveBufferSize in class AbstractConnectionFactorysoReceiveBufferSize - the soReceiveBufferSize to setpublic int getSoSendBufferSize()
getSoSendBufferSize in class AbstractConnectionFactorypublic void setSoSendBufferSize(int soSendBufferSize)
setSoSendBufferSize in class AbstractConnectionFactorysoSendBufferSize - the soSendBufferSize to setpublic boolean isSoTcpNoDelay()
isSoTcpNoDelay in class AbstractConnectionFactorypublic void setSoTcpNoDelay(boolean soTcpNoDelay)
setSoTcpNoDelay in class AbstractConnectionFactorysoTcpNoDelay - the soTcpNoDelay to setpublic int getSoLinger()
getSoLinger in class AbstractConnectionFactorypublic void setSoLinger(int soLinger)
setSoLinger in class AbstractConnectionFactorysoLinger - the soLinger to setpublic boolean isSoKeepAlive()
isSoKeepAlive in class AbstractConnectionFactorypublic void setSoKeepAlive(boolean soKeepAlive)
setSoKeepAlive in class AbstractConnectionFactorysoKeepAlive - the soKeepAlive to setpublic int getSoTrafficClass()
getSoTrafficClass in class AbstractConnectionFactorypublic void setSoTrafficClass(int soTrafficClass)
setSoTrafficClass in class AbstractConnectionFactorysoTrafficClass - the soTrafficClass to setpublic String getHost()
getHost in class AbstractConnectionFactorypublic int getPort()
getPort in class AbstractConnectionFactorypublic TcpSender getSender()
getSender in class AbstractConnectionFactorypublic Serializer<?> getSerializer()
getSerializer in class AbstractConnectionFactorypublic Deserializer<?> getDeserializer()
getDeserializer in class AbstractConnectionFactorypublic TcpMessageMapper getMapper()
getMapper in class AbstractConnectionFactorypublic void registerListener(TcpListener listener)
During initialization, if a factory detects it has no listener it's listening logic (active thread) is terminated.
The listener registered with a factory is provided to each connection it creates so it can call the onMessage() method.
This code satisfies the first requirement in that this listener signals to the factory that it needs to run its listening logic.
When we wrap actual connections with CachedConnections, the connection is given the wrapper as a listener, so it can enhance the headers in onMessage(); the wrapper then invokes the real listener supplied here, with the modified message.
registerListener in class AbstractConnectionFactorylistener - the TcpListener.public void registerSender(TcpSender sender)
AbstractConnectionFactoryregisterSender in class AbstractConnectionFactorysender - The senderpublic void setTaskExecutor(Executor taskExecutor)
setTaskExecutor in class AbstractConnectionFactorytaskExecutor - the taskExecutor to setpublic void setDeserializer(Deserializer<?> deserializer)
setDeserializer in class AbstractConnectionFactorydeserializer - the deserializer to setpublic void setSerializer(Serializer<?> serializer)
setSerializer in class AbstractConnectionFactoryserializer - the serializer to setpublic void setMapper(TcpMessageMapper mapper)
setMapper in class AbstractConnectionFactorymapper - the mapper to set; defaults to a TcpMessageMapperpublic boolean isSingleUse()
isSingleUse in class AbstractConnectionFactorypublic void setSingleUse(boolean singleUse)
setSingleUse in class AbstractConnectionFactorysingleUse - the singleUse.public void setInterceptorFactoryChain(TcpConnectionInterceptorFactoryChain interceptorFactoryChain)
setInterceptorFactoryChain in class AbstractConnectionFactorypublic void setLookupHost(boolean lookupHost)
AbstractConnectionFactorysetLookupHost in class AbstractConnectionFactorylookupHost - the lookupHost to setpublic boolean isLookupHost()
isLookupHost in class AbstractConnectionFactorypublic void forceClose(TcpConnection connection)
AbstractClientConnectionFactoryforceClose in class AbstractClientConnectionFactoryconnection - The connection.public void enableManualListenerRegistration()
AbstractClientConnectionFactoryTcpListener to the
 connections created by this factory. By default, the factory automatically configures
 the listener. When manual registration is in place, incoming messages will be delayed
 until the listener is registered.enableManualListenerRegistration in class AbstractClientConnectionFactorypublic void start()
start in interface Lifecyclestart in interface ManageableLifecyclestart in class AbstractConnectionFactorypublic void stop()
AbstractConnectionFactorystop in interface Lifecyclestop in interface ManageableLifecyclestop in class AbstractConnectionFactorypublic void destroy()
             throws Exception
destroy in interface DisposableBeanException