Class StompBrokerRelayMessageHandler
- All Implemented Interfaces:
Aware, ApplicationEventPublisherAware, Lifecycle, Phased, SmartLifecycle, MessageHandler
MessageHandler that handles messages by
forwarding them to a STOMP broker.
For each new CONNECT message, an independent TCP
connection to the broker is opened and used exclusively for all messages from the
client that originated the CONNECT message. Messages from the same client are
identified through the session id message header. Reversely, when the STOMP broker
sends messages back on the TCP connection, those messages are enriched with the
session id of the client and sent back downstream through the MessageChannel
provided to the constructor.
This class also automatically opens a default "system" TCP connection to the message broker that is used for sending messages that originate from the server application (as opposed to from a client). Such messages are not associated with any client and therefore do not have a session id header. The "system" connection is effectively shared and cannot be used to receive messages. Several properties are provided to configure the "system" connection including:
- Since:
- 4.0
- Author:
- Rossen Stoyanchev, Andy Wilkinson
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic interfaceContract for access to session counters. -
Field Summary
FieldsFields inherited from class AbstractBrokerMessageHandler
loggerFields inherited from interface SmartLifecycle
DEFAULT_PHASE -
Constructor Summary
ConstructorsConstructorDescriptionStompBrokerRelayMessageHandler(SubscribableChannel inboundChannel, MessageChannel outboundChannel, SubscribableChannel brokerChannel, Collection<String> destinationPrefixes) Create a StompBrokerRelayMessageHandler instance with the given message channels and destination prefixes. -
Method Summary
Modifier and TypeMethodDescriptionReturn the configured login to use for connections to the STOMP broker on behalf of connected clients.Return the configured passcode to use for connections to the STOMP broker on behalf of connected clients.intReturn the current count of TCP connection to the broker.Return the configured header initializer.Return the STOMP message broker host.intReturn the STOMP message broker port.getStats()Return a structured object with internal state and counters.Return a String describing internal state and counters.longReturn the interval, in milliseconds, at which the "system" connection expects to receive heartbeats from the STOMP broker.longReturn the interval, in milliseconds, at which the "system" connection will send heartbeats to the STOMP broker.Return the login used for the shared "system" connection to the STOMP broker.Return the passcode used for the shared "system" connection to the STOMP broker.Return the configured map with subscriptions on the "system" connection.@Nullable TcpOperations<byte[]> Get the configured TCP client (nevernullunless not configured invoked and this method is invoked before the handler is started and hence a default implementation initialized).Return the configured virtual host value.protected voidhandleMessageInternal(Message<?> message) voidsetClientLogin(String clientLogin) Set the login to use when creating connections to the STOMP broker on behalf of connected clients.voidsetClientPasscode(String clientPasscode) Set the client passcode to use to create connections to the STOMP broker on behalf of connected clients.voidsetHeaderInitializer(@Nullable MessageHeaderInitializer headerInitializer) Configure aMessageHeaderInitializerto apply to the headers of all messages created through theStompBrokerRelayMessageHandlerthat are sent to the client outbound message channel.voidsetRelayHost(String relayHost) Set the STOMP message broker host.voidsetRelayPort(int relayPort) Set the STOMP message broker port.voidsetSystemHeartbeatReceiveInterval(long heartbeatReceiveInterval) Set the maximum interval, in milliseconds, at which the "system" connection expects, in the absence of any other data, to receive a heartbeat from the STOMP broker.voidsetSystemHeartbeatSendInterval(long systemHeartbeatSendInterval) Set the interval, in milliseconds, at which the "system" connection will, in the absence of any other data being sent, send a heartbeat to the STOMP broker.voidsetSystemLogin(String systemLogin) Set the login for the shared "system" connection used to send messages to the STOMP broker from within the application, i.e.voidsetSystemPasscode(String systemPasscode) Set the passcode for the shared "system" connection used to send messages to the STOMP broker from within the application, i.e.voidsetSystemSubscriptions(@Nullable Map<String, MessageHandler> subscriptions) Configure one more destinations to subscribe to on the shared "system" connection along with MessageHandler's to handle received messages.voidsetTaskScheduler(@Nullable TaskScheduler taskScheduler) Configure theTaskSchedulerto use to reset client-to-broker message count in the current heartbeat period.voidsetTcpClient(@Nullable TcpOperations<byte[]> tcpClient) Configure a TCP client for managing TCP connections to the STOMP broker.voidsetVirtualHost(@Nullable String virtualHost) Set the value of the "host" header to use in STOMP CONNECT frames.protected voidprotected voidtoString()Methods inherited from class AbstractBrokerMessageHandler
checkDestinationPrefix, getApplicationEventPublisher, getBrokerChannel, getClientInboundChannel, getClientOutboundChannel, getClientOutboundChannelForSession, getDestinationPrefixes, getPhase, handleMessage, isAutoStartup, isBrokerAvailable, isPreservePublishOrder, isRunning, publishBrokerAvailableEvent, publishBrokerUnavailableEvent, setApplicationEventPublisher, setAutoStartup, setPhase, setPreservePublishOrder, setUserDestinationPredicate, start, stop, stopMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface SmartLifecycle
isPauseable
-
Field Details
-
SYSTEM_SESSION_ID
-
-
Constructor Details
-
StompBrokerRelayMessageHandler
public StompBrokerRelayMessageHandler(SubscribableChannel inboundChannel, MessageChannel outboundChannel, SubscribableChannel brokerChannel, Collection<String> destinationPrefixes) Create a StompBrokerRelayMessageHandler instance with the given message channels and destination prefixes.- Parameters:
inboundChannel- the channel for receiving messages from clients (for example, WebSocket clients)outboundChannel- the channel for sending messages to clients (for example, WebSocket clients)brokerChannel- the channel for the application to send messages to the brokerdestinationPrefixes- the broker supported destination prefixes; destinations that do not match the given prefix are ignored.
-
-
Method Details
-
setRelayHost
Set the STOMP message broker host. -
getRelayHost
Return the STOMP message broker host. -
setRelayPort
public void setRelayPort(int relayPort) Set the STOMP message broker port. -
getRelayPort
public int getRelayPort()Return the STOMP message broker port. -
setClientLogin
Set the login to use when creating connections to the STOMP broker on behalf of connected clients.By default this is set to "guest".
- See Also:
-
getClientLogin
Return the configured login to use for connections to the STOMP broker on behalf of connected clients.- See Also:
-
setClientPasscode
Set the client passcode to use to create connections to the STOMP broker on behalf of connected clients.By default this is set to "guest".
- See Also:
-
getClientPasscode
Return the configured passcode to use for connections to the STOMP broker on behalf of connected clients.- See Also:
-
setSystemLogin
Set the login for the shared "system" connection used to send messages to the STOMP broker from within the application, i.e. messages not associated with a specific client session (for example, REST/HTTP request handling method).By default this is set to "guest".
-
getSystemLogin
Return the login used for the shared "system" connection to the STOMP broker. -
setSystemPasscode
Set the passcode for the shared "system" connection used to send messages to the STOMP broker from within the application, i.e. messages not associated with a specific client session (for example, REST/HTTP request handling method).By default this is set to "guest".
-
getSystemPasscode
Return the passcode used for the shared "system" connection to the STOMP broker. -
setSystemHeartbeatSendInterval
public void setSystemHeartbeatSendInterval(long systemHeartbeatSendInterval) Set the interval, in milliseconds, at which the "system" connection will, in the absence of any other data being sent, send a heartbeat to the STOMP broker. A value of zero will prevent heartbeats from being sent to the broker.The default value is 10000.
See class-level documentation for more information on the "system" connection.
-
getSystemHeartbeatSendInterval
public long getSystemHeartbeatSendInterval()Return the interval, in milliseconds, at which the "system" connection will send heartbeats to the STOMP broker. -
setSystemHeartbeatReceiveInterval
public void setSystemHeartbeatReceiveInterval(long heartbeatReceiveInterval) Set the maximum interval, in milliseconds, at which the "system" connection expects, in the absence of any other data, to receive a heartbeat from the STOMP broker. A value of zero will configure the connection to expect not to receive heartbeats from the broker.The default value is 10000.
See class-level documentation for more information on the "system" connection.
-
getSystemHeartbeatReceiveInterval
public long getSystemHeartbeatReceiveInterval()Return the interval, in milliseconds, at which the "system" connection expects to receive heartbeats from the STOMP broker. -
setSystemSubscriptions
Configure one more destinations to subscribe to on the shared "system" connection along with MessageHandler's to handle received messages.This is for internal use in a multi-application server scenario where servers forward messages to each other (for example, unresolved user destinations).
- Parameters:
subscriptions- the destinations to subscribe to.
-
getSystemSubscriptions
Return the configured map with subscriptions on the "system" connection. -
setVirtualHost
Set the value of the "host" header to use in STOMP CONNECT frames. When this property is configured, a "host" header will be added to every STOMP frame sent to the STOMP broker. This may be useful for example in a cloud environment where the actual host to which the TCP connection is established is different from the host providing the cloud-based STOMP service.By default this property is not set.
-
getVirtualHost
-
setTcpClient
Configure a TCP client for managing TCP connections to the STOMP broker.By default
ReactorNettyTcpClientis used.Note: when this property is used, any
hostorportspecified are effectively ignored. -
getTcpClient
Get the configured TCP client (nevernullunless not configured invoked and this method is invoked before the handler is started and hence a default implementation initialized). -
setHeaderInitializer
Configure aMessageHeaderInitializerto apply to the headers of all messages created through theStompBrokerRelayMessageHandlerthat are sent to the client outbound message channel.By default this property is not set.
-
getHeaderInitializer
Return the configured header initializer. -
getStatsInfo
Return a String describing internal state and counters. EffectivelytoString()ongetStats(). -
getStats
Return a structured object with internal state and counters.- Since:
- 5.2
-
getConnectionCount
public int getConnectionCount()Return the current count of TCP connection to the broker. -
setTaskScheduler
Configure theTaskSchedulerto use to reset client-to-broker message count in the current heartbeat period. For more details, seeStompBrokerRelayRegistration.setTaskScheduler(TaskScheduler).- Parameters:
taskScheduler- the scheduler to use- Since:
- 5.3
-
getTaskScheduler
-
startInternal
protected void startInternal()- Overrides:
startInternalin classAbstractBrokerMessageHandler
-
stopInternal
protected void stopInternal()- Overrides:
stopInternalin classAbstractBrokerMessageHandler
-
handleMessageInternal
- Specified by:
handleMessageInternalin classAbstractBrokerMessageHandler
-
toString
-