Class ZeroMqMessageProducer
java.lang.Object
org.springframework.integration.context.IntegrationObjectSupport
org.springframework.integration.endpoint.AbstractEndpoint
org.springframework.integration.endpoint.MessageProducerSupport
org.springframework.integration.zeromq.inbound.ZeroMqMessageProducer
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- BeanNameAware,- DisposableBean,- InitializingBean,- SmartInitializingSingleton,- ApplicationContextAware,- Lifecycle,- Phased,- SmartLifecycle,- ComponentSourceAware,- ExpressionCapable,- MessageProducer,- IntegrationPattern,- NamedComponent,- IntegrationInboundManagement,- IntegrationManagement,- ManageableLifecycle,- ManageableSmartLifecycle,- TrackableComponent
@ManagedResource
@IntegrationManagedResource
public class ZeroMqMessageProducer
extends MessageProducerSupport
A 
MessageProducerSupport implementation for consuming messages from ZeroMq socket.
 Only SocketType.PAIR, SocketType.SUB and SocketType.PULL are supported.
 This component can bind or connect the socket.
 
 When the SocketType.SUB is used, the received topic is stored in the ZeroMqHeaders.TOPIC.
- Since:
- 5.4
- Author:
- Artem Bilan, Alessio Matricardi
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.springframework.integration.support.management.IntegrationManagementIntegrationManagement.ManagementOverrides
- 
Field SummaryFieldsFields inherited from class org.springframework.integration.endpoint.AbstractEndpointlifecycleLockFields inherited from class org.springframework.integration.context.IntegrationObjectSupportEXPRESSION_PARSER, loggerFields inherited from interface org.springframework.integration.support.management.IntegrationManagementMETER_PREFIX, RECEIVE_COUNTER_NAME, SEND_TIMER_NAMEFields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
- 
Constructor SummaryConstructorsConstructorDescriptionZeroMqMessageProducer(org.zeromq.ZContext context) ZeroMqMessageProducer(org.zeromq.ZContext context, org.zeromq.SocketType socketType) 
- 
Method SummaryModifier and TypeMethodDescriptionvoiddestroy()protected voiddoStart()Take no action by default.protected voiddoStop()Take no action by default.intReturn the port a socket is bound or 0 if this message producer has not been started yet or the socket is connected - not bound.protected voidonInit()Subclasses may implement this for initialization logic.voidsetBindPort(int port) Configure a port for TCP protocol binding viaZMQ.Socket.bind(String).voidsetConnectUrl(@Nullable String connectUrl) Configure an URL forZMQ.Socket.connect(String).voidsetConsumeDelay(Duration consumeDelay) Specify aDurationto delay consumption when no data received.voidsetMessageConverter(MessageConverter messageConverter) Provide aMessageConverter(as an alternative tomessageMapper) for converting a consumed data into a message to produce.voidsetMessageMapper(InboundMessageMapper<byte[]> messageMapper) Provide anInboundMessageMapperto convert a consumed data into a message to produce.voidsetReceiveRaw(boolean receiveRaw) Whether rawZMsgis present as a payload of message to produce or it is fully converted to aMessageincludingZeroMqHeaders.TOPICheader (if any).voidsetSocketConfigurer(Consumer<org.zeromq.ZMQ.Socket> socketConfigurer) Provide aConsumerto configure a socket with arbitrary options, like security.voidSpecify topics theSocketType.SUBsocket is going to use for subscription.voidsubscribeToTopics(String... topics) voidunsubscribeFromTopics(String... topics) voidunwrapTopic(boolean unwrapTopic) Specify if the topic thatSocketType.SUBsocket is going to receive is wrapped with an additional empty frame.Methods inherited from class org.springframework.integration.endpoint.MessageProducerSupportafterSingletonsInstantiated, buildErrorMessage, getErrorChannel, getErrorMessageAttributes, getErrorMessageStrategy, getIntegrationPatternType, getMessagingTemplate, getOutputChannel, getRequiredOutputChannel, isObserved, registerObservationRegistry, sendErrorMessageIfNecessary, sendMessage, setErrorChannel, setErrorChannelName, setErrorMessageStrategy, setObservationConvention, setOutputChannel, setOutputChannelName, setSendTimeout, setShouldTrack, subscribeToPublisherMethods inherited from class org.springframework.integration.endpoint.AbstractEndpointdoStop, getPhase, getRole, isActive, isAutoStartup, isRunning, setAutoStartup, setPhase, setRole, start, stop, stopMethods inherited from class org.springframework.integration.context.IntegrationObjectSupportafterPropertiesSet, extractTypeIfPossible, generateId, getApplicationContext, getApplicationContextId, getBeanDescription, getBeanFactory, getBeanName, getChannelResolver, getComponentDescription, getComponentName, getComponentSource, getConversionService, getExpression, getIntegrationProperties, getMessageBuilderFactory, getTaskScheduler, isInitialized, setApplicationContext, setBeanFactory, setBeanName, setChannelResolver, setComponentDescription, setComponentName, setComponentSource, setConversionService, setMessageBuilderFactory, setPrimaryExpression, setTaskScheduler, toStringMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.integration.support.management.IntegrationManagementgetManagedName, getManagedType, getOverrides, getThisAs, isLoggingEnabled, registerMetricsCaptor, setLoggingEnabled, setManagedName, setManagedTypeMethods inherited from interface org.springframework.integration.support.context.NamedComponentgetBeanName, getComponentNameMethods inherited from interface org.springframework.context.SmartLifecycleisPauseable
- 
Field Details- 
DEFAULT_CONSUME_DELAY
 
- 
- 
Constructor Details- 
ZeroMqMessageProducerpublic ZeroMqMessageProducer(org.zeromq.ZContext context) 
- 
ZeroMqMessageProducerpublic ZeroMqMessageProducer(org.zeromq.ZContext context, org.zeromq.SocketType socketType) 
 
- 
- 
Method Details- 
setConsumeDelaySpecify aDurationto delay consumption when no data received.- Parameters:
- consumeDelay- the- Durationto delay consumption when empty; defaults to- DEFAULT_CONSUME_DELAY.
 
- 
setMessageMapperProvide anInboundMessageMapperto convert a consumed data into a message to produce. Ignored whensetReceiveRaw(boolean)istrue.- Parameters:
- messageMapper- the- InboundMessageMapperto use.
 
- 
setMessageConverterProvide aMessageConverter(as an alternative tomessageMapper) for converting a consumed data into a message to produce. Ignored whensetReceiveRaw(boolean)istrue.- Parameters:
- messageConverter- the- MessageConverterto use.
 
- 
setReceiveRawpublic void setReceiveRaw(boolean receiveRaw) Whether rawZMsgis present as a payload of message to produce or it is fully converted to aMessageincludingZeroMqHeaders.TOPICheader (if any).- Parameters:
- receiveRaw- to convert from- ZMsgor not; defaults to convert.
 
- 
setSocketConfigurer
- 
setTopicsSpecify topics theSocketType.SUBsocket is going to use for subscription. It is ignored for all otherSocketTypes supported.- Parameters:
- topics- the topics to use.
 
- 
setConnectUrlConfigure an URL forZMQ.Socket.connect(String). Mutually exclusive with thesetBindPort(int).- Parameters:
- connectUrl- the URL to connect ZeroMq socket to.
 
- 
setBindPortpublic void setBindPort(int port) Configure a port for TCP protocol binding viaZMQ.Socket.bind(String). Mutually exclusive with thesetConnectUrl(String).- Parameters:
- port- the port to bind ZeroMq socket to over TCP.
 
- 
getBoundPortpublic int getBoundPort()Return the port a socket is bound or 0 if this message producer has not been started yet or the socket is connected - not bound.- Returns:
- the port for a socket or 0.
 
- 
unwrapTopicpublic void unwrapTopic(boolean unwrapTopic) Specify if the topic thatSocketType.SUBsocket is going to receive is wrapped with an additional empty frame. It is ignored for all otherSocketTypes supported. This attribute is set totrueby default.- Parameters:
- unwrapTopic- true if the received topic is wrapped with an additional empty frame.
- Since:
- 6.2.6
 
- 
getComponentType- Specified by:
- getComponentTypein interface- NamedComponent
- Overrides:
- getComponentTypein class- MessageProducerSupport
 
- 
onInitprotected void onInit()Description copied from class:IntegrationObjectSupportSubclasses may implement this for initialization logic.- Overrides:
- onInitin class- MessageProducerSupport
 
- 
subscribeToTopics
- 
unsubscribeFromTopics
- 
doStartprotected void doStart()Description copied from class:MessageProducerSupportTake no action by default. Subclasses may override this if they need lifecycle-managed behavior. Protected by 'lifecycleLock'.- Overrides:
- doStartin class- MessageProducerSupport
 
- 
doStopprotected void doStop()Description copied from class:MessageProducerSupportTake no action by default. Subclasses may override this if they need lifecycle-managed behavior.- Overrides:
- doStopin class- MessageProducerSupport
 
- 
destroypublic void destroy()- Specified by:
- destroyin interface- DisposableBean
- Specified by:
- destroyin interface- IntegrationManagement
- Overrides:
- destroyin class- AbstractEndpoint
 
 
-