The default mode for managing subscriptions is auto-subscribe. Every time a subscriber endpoint starts, it determines which events it needs to subscribe to and automatically subscribes to them. For more information on how publish and subscribe works, refer to Publish-Subscribe.
Messages matching both of the following criteria will be auto-subscribed at startup:
- Defined as an event either using
IEventor by the
- At least one message handler and/or saga exists for the given event.
Sagas are treated the same as handlers and will cause an endpoint to subscribe to a given event. It is possible to opt-in to the old exclude saga event handling behavior using:
var autoSubscribe = busConfiguration.AutoSubscribe(); autoSubscribe.DoNotAutoSubscribeSagas();
In NServiceBus versions 4 and 5, it is possible to opt-in to automatically subscribe to all messages not defined as a command using
ICommand or the
. convention using the following code:
var autoSubscribe = busConfiguration.AutoSubscribe(); autoSubscribe.AutoSubscribePlainMessages();
A subscriber will not unsubscribe when it stops; it will remain registered at the publisher to receive events. The publisher still sends events to the queue of the stopped subscriber. When the subscriber is started, it will consume the messages from its queue. The subscriber will never lose an event.
Automatic subscriptions by the infrastructure can be disabled using the configuration API:
Events can manually be subscribed and unsubscribed to: