Getting Started
Architecture
Transports
Persistence
ServiceInsight
ServicePulse
ServiceControl
Monitoring
Modernization
Samples

Message Headers

Component: NServiceBus
NuGet Package: NServiceBus 9.x

The headers of a message are similar to HTTP headers and contain metadata about the message being sent over the queueing system. This document describes the headers used by NServiceBus. To learn more about how to use custom headers, see the documentation on manipulating message headers.

Timestamp format

For all timestamp message headers, the format is yyyy-MM-dd HH:mm:ss:ffffff Z, where the time is UTC. The helper class DateTimeOffsetHelper supports converting from UTC to wire format and vice versa by using the ToWireFormattedString(DateTimeOffset) and ToDateTimeOffset(string) methods.

ISO 8601 format

This is NOT the ISO 8601 format but a custom format.

Differences:

  1. a T between date and time
  2. uses a . between seconds and milli/microseconds
  3. no space between the timestamp and the Z
ISO 8601:    yyyy-MM-ddTHH:mm:ss.ffffffZ
NServiceBus: yyyy-MM-dd HH:mm:ss:ffffff Z

When doing native intergration and there is a need to parse the timestamp the . as second and milli/microsecond separator is where regular timestamp parsers often fail.

Transport headers

NServiceBus.NonDurableMessage

The NonDurableMessage header controls non-durable messaging persistence behavior of in-flight messages. The behavior is transport-specific, but the intent is to not store the message durably on disk and only keep it in memory.

NServiceBus.TimeToBeReceived

The TimeToBeReceived header controls when a message becomes obsolete and can be discarded. The behavior is transport-dependent.

NServiceBus.Transport.Encoding

States what type of body serialization is used.

It is used only by the legacy Azure Service Bus transport (NServiceBus.Azure.Transports.WindowsAzureServiceBus package), which is no longer supported.

Serialization headers

The following headers include information for the receiving endpoint on the message serialization option that was used.

NServiceBus.ContentType

The type of serialization used for the message, for example, text/xml, text/json, application/json, or application/json; systemjson.

In some cases, the NServiceBus.Version header may be useful for determining how to use the value in this header appropriately.

NServiceBus.EnclosedMessageTypes

The fully qualified .NET type name of the enclosed message(s). The receiving endpoint will use this type when deserializing an incoming message. Depending on the versioning strategy the type can be specified in the following ways:

  • Full type name: Namespace.ClassName.
  • Assembly qualified name: Namespace.ClassName, AssemblyName, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null.

See the message type detection documentation for more details.

Messaging interaction headers

The following headers enable different messaging interaction patterns, such as Request-Response.

NServiceBus.MessageId

A unique ID for the current message.

NServiceBus.CorrelationId

NServiceBus implements the Correlation Identifier pattern by using a Correlation Id header.

Message correlation connects request messages with their corresponding response messages. The Correlation Id of the response message is the Correlation Id of its corresponding request message. Each outgoing message which is sent outside of a message handler will have its Correlation Id set to its Message Id.

An example of Correlation Identifier usage within NServiceBus can be found in callbacks.

Messages sent from a saga using the ReplyToOriginator method will have their Correlation Id set based on the message which caused the saga to be created. See Notifying callers of status for more information about the ReplyToOriginator method.

CorrId

CorrId is an MSMQ specific header semantically identical to NServiceBus.CorrelationId. It is included only for backward compatibility with endpoints running version 3 or older of NServiceBus.

NServiceBus.ConversationId

The identifier of the conversation that this message is part of. It enables the tracking of message flows that span more than one message exchange. ConversationId, RelatedTo, OriginatingEndpoint, and ProcessingEndpoint fields allow ServicePulse to reconstruct the entire message flow.

The first message sent in a new flow is automatically assigned a unique ConversationId that gets propagated to all the messages that are sent afterward, forming a conversation. Each message sent within a conversation has a RelatedTo value that identifies the message that caused it to be sent.

The ConversationId must be assigned manually in cases where NServiceBus can't infer when messages belong to the same conversation. For example, when a CancelOrder message must be part of an existing order conversation, the Order ID can be used as the Conversation ID. Manually assigning a ConversationId can be achieved by overriding the header with a custom value:

var sendOptions = new SendOptions();
sendOptions.SetHeader(Headers.ConversationId, "MyCustomConversationId/" + System.Guid.NewGuid());
await context.Send(new MyMessage(), sendOptions);

To get full control over the Conversation ID, a custom convention can be registered:

config.CustomConversationIdStrategy(context =>
{
    if (context.Message.Instance is CancelOrder)
    {
        //use the order id as the conversation id
        return ConversationId.Custom("Order/" + ((CancelOrder)context.Message.Instance).OrderId);
    }

    //use the default generated id
    return ConversationId.Default;
});

This is useful to avoid setting the Conversation ID when sending individual messages but rather apply a convention using a custom attribute, inheriting from an interface, using reflection based on message types, or some other method.

Starting a new conversation

In some scenarios though, starting a new conversation might be desirable. For example, a batch import that reads thousands of records and starts a workflow on each one would normally result in a giant visualization, where it would be more appropriate for each record to be a new conversation.

Starting a new conversation can be done with the help of SendOptions:

var sendOptions = new SendOptions();
sendOptions.StartNewConversation();

await context.Send(new CancelOrder(), sendOptions);

A custom Conversation ID can also be provided:

var sendOptions = new SendOptions();
sendOptions.StartNewConversation("MyCustomConversationId/" + System.Guid.NewGuid());

await context.Send(new CancelOrder(), sendOptions);

NServiceBus.RelatedTo

The MessageId that caused the current message to be sent. Whenever a message is sent or published from inside a message handler, its RelatedTo header is set to the MessageId of the incoming message being handled.

NServiceBus.MessageIntent

Message intent can have one of the following values:

ValueDescription
SendRegular point-to-point send. Note that messages sent to the error queue will also have a Send intent
PublishThe message is an event that has been published and will be sent to all subscribers.
SubscribeA control message indicating that the source endpoint wants to subscribe to a specific message.
UnsubscribeA control message indicating that the source endpoint wants to unsubscribe to a specific message.
ReplyThe message has been initiated by doing a Reply or a Return from within a Handler or a Saga.

NServiceBus.ControlMessage

Indicates that the message is a control message, i.e., it has no body, and the intent of the message and any data are transmitted in the message headers.

NServiceBus.ReplyToAddress

Downstream message handlers or sagas use this value as the reply queue address when replying or returning a message.

Send headers

When a message is sent, the headers will be as follows:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 5899fb83-8306-43f2-90c1-b33e0182e118
NServiceBus.CorrelationId = b3f390a6-f577-4ac6-9146-b33e0182e118
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = b3f390a6-f577-4ac6-9146-b33e0182e118
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterSend
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterSend
NServiceBus.TimeSent = 2025-08-19 23:28:35:060376 Z
NServiceBus.Version = 9.2.7

In the above example, the headers are for a Send operation, and hence, the MessageIntent header is Send. If the message were published instead, the MessageIntent header would be Publish.

Reply headers

When replying to a message:

  • The MessageIntent is Reply.
  • The RelatedTo will be the same as the initiating MessageID.
  • The ConversationId will be the same as the initiating ConversationId.
  • The CorrelationId will be the same as the initiating CorrelationId.

Example reply headers

Given an initiating message with the following headers:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 43490b7e-9e3b-46ba-b277-b33e0182e0ec
NServiceBus.CorrelationId = c214faf0-9a99-4042-a89c-b33e0182e0eb
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = c214faf0-9a99-4042-a89c-b33e0182e0eb
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterReply
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterReply
NServiceBus.TimeSent = 2025-08-19 23:28:34:912631 Z
NServiceBus.Version = 9.2.7

The headers of the reply message will be:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 43490b7e-9e3b-46ba-b277-b33e0182e0ec
NServiceBus.CorrelationId = c214faf0-9a99-4042-a89c-b33e0182e0eb
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToReply, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = d06ea2ac-57c1-43e4-820f-b33e0182e0f0
NServiceBus.MessageIntent = Reply
NServiceBus.OriginatingEndpoint = HeaderWriterReply
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.RelatedTo = c214faf0-9a99-4042-a89c-b33e0182e0eb
NServiceBus.ReplyToAddress = HeaderWriterReply
NServiceBus.TimeSent = 2025-08-19 23:28:34:927125 Z
NServiceBus.Version = 9.2.7

Publish headers

When a message is published, the headers will be as follows:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = c9bbd66d-144d-4954-82ea-b33e0182e0d2
NServiceBus.CorrelationId = 43c170a8-c7ad-4ed0-b1eb-b33e0182e0d2
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToPublish, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 43c170a8-c7ad-4ed0-b1eb-b33e0182e0d2
NServiceBus.MessageIntent = Publish
NServiceBus.OriginatingEndpoint = HeaderWriterPublish
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterPublish
NServiceBus.TimeSent = 2025-08-19 23:28:34:828989 Z
NServiceBus.Version = 9.2.7

Return from a handler

When returning a message instead of replying:

  • The Return has the same points as the Reply example above but with some additions.
  • The ReturnMessage.ErrorCode contains the value supplied to the Bus.Return method.

Example return headers

Given an initiating message with the following headers:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 3119c015-e0c5-4a82-9a20-b33e0182e0f8
NServiceBus.CorrelationId = 058e8c9d-3a50-466c-8c09-b33e0182e0f8
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 058e8c9d-3a50-466c-8c09-b33e0182e0f8
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterReturn
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterReturn
NServiceBus.TimeSent = 2025-08-19 23:28:34:954450 Z
NServiceBus.Version = 9.2.7

The headers of the reply message will be:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ControlMessage = True
NServiceBus.ConversationId = 3119c015-e0c5-4a82-9a20-b33e0182e0f8
NServiceBus.CorrelationId = 058e8c9d-3a50-466c-8c09-b33e0182e0f8
NServiceBus.MessageId = 9be54b5e-56f1-489d-a3db-b33e0182e0fc
NServiceBus.MessageIntent = Reply
NServiceBus.OriginatingEndpoint = HeaderWriterReturn
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.RelatedTo = 058e8c9d-3a50-466c-8c09-b33e0182e0f8
NServiceBus.ReplyToAddress = HeaderWriterReturn
NServiceBus.ReturnMessage.ErrorCode = 100
NServiceBus.TimeSent = 2025-08-19 23:28:34:966585 Z
NServiceBus.Version = 9.2.7

Timeout headers

NServiceBus.ClearTimeouts

This is a header to indicate that the contained control message requests that timeouts be cleared for a given saga.

NServiceBus.Timeout.Expire

A timestamp that indicates when a timeout should be fired.

NServiceBus.Timeout.RouteExpiredTimeoutTo

The queue name to which a timeout should be routed back to when it expires.

NServiceBus.IsDeferredMessage

A header to indicate that this message resulted from a message deferral.

Saga-related headers

When a message is dispatched from within a saga, the message will contain the following headers:

  • OriginatingSagaId: matches the ID used as the index for the saga data stored in persistence.
  • OriginatingSagaType: the fully qualified type name of the saga that sent the message.

Example "send from saga" headers

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 44172daa-9fcb-4bd3-a215-b33e0182e106
NServiceBus.CorrelationId = 23befda3-ef67-4d73-9901-b33e0182e105
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.SendFromSagaMessage, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = f41ed996-3cd1-4202-b3be-b33e0182e10b
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterSaga
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.OriginatingSagaId = 5c1134ed-d7e8-9308-3fd4-8dd20015bea6
NServiceBus.OriginatingSagaType = Core.Headers.Writers.MyNamespace.Saga1, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.RelatedTo = 23befda3-ef67-4d73-9901-b33e0182e105
NServiceBus.ReplyToAddress = HeaderWriterSaga
NServiceBus.TimeSent = 2025-08-19 23:28:35:016453 Z
NServiceBus.Version = 9.2.7

Replying to a saga

A message reply is performed from a saga will have the following headers:

  • The send headers are the same as a standard reply header with a few additions.
  • Since this reply is from a secondary saga, then OriginatingSagaId and OriginatingSagaType will match the second saga.
  • Since this is a reply to the initial saga, the headers will contain SagaId and SagaType headers matching the initial saga.

Example "replying to a saga" headers

Via calling Bus.Reply

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 44172daa-9fcb-4bd3-a215-b33e0182e106
NServiceBus.CorrelationId = 23befda3-ef67-4d73-9901-b33e0182e105
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.ReplyFromSagaMessage, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 5929f6a7-e48b-4270-bb78-b33e0182e10c
NServiceBus.MessageIntent = Reply
NServiceBus.OriginatingEndpoint = HeaderWriterSaga
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.OriginatingSagaId = 4c768073-23cb-7a6d-9965-9a36ba67a3f7
NServiceBus.OriginatingSagaType = Core.Headers.Writers.MyNamespace.Saga2, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.RelatedTo = f41ed996-3cd1-4202-b3be-b33e0182e10b
NServiceBus.ReplyToAddress = HeaderWriterSaga
NServiceBus.SagaId = 5c1134ed-d7e8-9308-3fd4-8dd20015bea6
NServiceBus.SagaType = Core.Headers.Writers.MyNamespace.Saga1, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.TimeSent = 2025-08-19 23:28:35:022025 Z
NServiceBus.Version = 9.2.7

Via calling Saga.ReplyToOriginator

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 44172daa-9fcb-4bd3-a215-b33e0182e106
NServiceBus.CorrelationId = f41ed996-3cd1-4202-b3be-b33e0182e10b
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.ReplyToOriginatorFromSagaMessage, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = b543e6e6-98b6-40dc-8dea-b33e0182e10d
NServiceBus.MessageIntent = Reply
NServiceBus.OriginatingEndpoint = HeaderWriterSaga
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.OriginatingSagaId = 4c768073-23cb-7a6d-9965-9a36ba67a3f7
NServiceBus.OriginatingSagaType = Core.Headers.Writers.MyNamespace.Saga2, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.RelatedTo = f41ed996-3cd1-4202-b3be-b33e0182e10b
NServiceBus.ReplyToAddress = HeaderWriterSaga
NServiceBus.TimeSent = 2025-08-19 23:28:35:022513 Z
NServiceBus.Version = 9.2.7

Requesting a timeout from a saga

When requesting a timeout from a saga:

  • The OriginatingSagaId, OriginatingSagaType, SagaId and SagaType will all match the Saga that requested the Timeout.
  • The Timeout.RouteExpiredTimeoutTo header contains the queue name for where the callback for the timeout should be sent.
  • The Timeout.Expire header contains the timestamp for when the timeout should fire.

Example timeout headers

$.diagnostics.originating.hostid = 8cf0a8f78f9cd1885699777c83eb631e
CorrId = cb4c79a4-476c-4e64-aff1-a5eb011ad6e5\0
NServiceBus.ContentType = text/xml
NServiceBus.ConversationId = dbaf0a21-9b6a-49bd-ae76-a5eb011ad6df
NServiceBus.CorrelationId = cb4c79a4-476c-4e64-aff1-a5eb011ad6e5
NServiceBus.EnclosedMessageTypes = Core6.Headers.Writers.MyNamespace.TimeoutFromSaga, MyAssembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.IsSagaTimeoutMessage = True
NServiceBus.MessageId = 433d5c9f-4968-4bf9-9c7e-a5eb011ad72a
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterSagaV6
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.OriginatingSagaId = 25b7653a-5612-4e9e-b78f-a5eb011ad729
NServiceBus.OriginatingSagaType = Core6.Headers.Writers.MyNamespace.Saga2, MyAssembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.RelatedTo = cb4c79a4-476c-4e64-aff1-a5eb011ad6e5
NServiceBus.ReplyToAddress = HeaderWriterSagaV6@MACHINENAME
NServiceBus.SagaId = 25b7653a-5612-4e9e-b78f-a5eb011ad729
NServiceBus.SagaType = Core6.Headers.Writers.MyNamespace.Saga2, MyAssembly, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.Timeout.Expire = 2016-04-17 07:09:47:444081 Z
NServiceBus.Timeout.RouteExpiredTimeoutTo = HeaderWriterSagaV6@MACHINENAME
NServiceBus.TimeSent = 2016-04-17 07:09:47:443081 Z
NServiceBus.Version = 6.0.0

Defer a message

When deferring, the message will have similar headers compared to a send, but will be delivered later.

In NServiceBus version 7.7 and above, the DeliverAt header will also be added containing the time when the message was targeted to be delivered.

Example defer headers

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = af516ad8-203e-46d5-8fa7-b33e0182dbed
NServiceBus.CorrelationId = 6311dbbd-e939-4e15-aa0d-b33e0182dbed
NServiceBus.DeliverAt = 2025-08-19 23:28:30:660742 Z
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 6311dbbd-e939-4e15-aa0d-b33e0182dbed
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterDefer
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterDefer
NServiceBus.TimeSent = 2025-08-19 23:28:30:650742 Z
NServiceBus.Version = 9.2.7

Diagnostic and informational headers

Headers used to give visibility into the "where," "when," and "by whom" of a message. They are used by ServiceControl, ServiceInsight and ServicePulse.

$.diagnostics

The host details of the endpoint where the message was being processed. This header contains three parts:

  • $.diagnostics.hostdisplayname
  • $.diagnostics.hostid
  • $.diagnostics.originating.hostid

NServiceBus.TimeSent

The timestamp when the message was sent, used by the Performance Counters.

NServiceBus.DeliverAt

The timestamp when the message should be delivered. Used for more accurate calculation of critical time.

NServiceBus.OriginatingEndpoint

The endpoint name the message was sent from.

NServiceBus.OriginatingMachine

The machine name the message was sent from.

NServiceBus.Version

The NServiceBus version number.

OpenTelemetry-related headers

These headers are added when OpenTelemetry is enabled for an endpoint, in accordance with the W3C Trace Context specification:

Audit headers

Headers added when a message is audited.

NServiceBus.ProcessingEnded

The timestamp when the processing of a message ended.

NServiceBus.ProcessingEndpoint

Name of the endpoint where the message was processed.

NServiceBus.ProcessingMachine

The machine name of the endpoint where the message was processed.

NServiceBus.ProcessingStarted

The timestamp when the processing of this message started.

Example audit headers

Given an initiating message with the following headers:

$.diagnostics.hostdisplayname = MACHINENAME
$.diagnostics.hostid = 7f787fc8e0611a3fab8a93c8767f6639
$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 2bdb067f-3f84-43b3-8714-b33e015fd41c
NServiceBus.CorrelationId = f0c10692-9e03-43d1-bd43-b33e015fd41c
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = f0c10692-9e03-43d1-bd43-b33e015fd41c
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterAudit
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ProcessingEnded = 2025-08-19 23:21:59:478145 Z
NServiceBus.ProcessingEndpoint = HeaderWriterAudit
NServiceBus.ProcessingMachine = MACHINENAME
NServiceBus.ProcessingStarted = 2025-08-19 23:21:59:477486 Z
NServiceBus.ReplyToAddress = HeaderWriterAudit
NServiceBus.TimeSent = 2025-08-19 21:20:58:118997 Z
NServiceBus.Version = 9.2.7

when that message fails to be processed, it will be sent to the error queue with the following headers:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 14618a9a-1cbc-4e7b-a7f4-b33e0181117b
NServiceBus.CorrelationId = cbb1f034-c884-4ce0-8673-b33e0181117a
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = cbb1f034-c884-4ce0-8673-b33e0181117a
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterAudit
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterAudit
NServiceBus.TimeSent = 2025-08-19 23:21:59:447694 Z
NServiceBus.Version = 9.2.7

Retries handling headers

Headers used to facilitate retries.

NServiceBus.Retries

The number of delayed retries that have been performed for a message.

NServiceBus.Retries.Timestamp

A timestamp used by delayed retries to determine if the maximum time for retrying has been reached.

Error forwarding headers

When a message exhausts the configured number of retry attempts and is moved to the error queue by the recoverability component, it will have the following extra headers added to the existing headers.

NServiceBus.FailedQ

The queue at which the message processing failed.

NServiceBus.ExceptionInfo.ExceptionType

The Type.FullName of the Exception. It is obtained by calling Exception.GetType().FullName.

NServiceBus.ExceptionInfo.InnerExceptionType

The full type name of the InnerException if it exists. It is obtained by calling Exception.InnerException.GetType().FullName.

NServiceBus.ExceptionInfo.HelpLink

The exception help link.

NServiceBus.ExceptionInfo.Message

The exception message.

NServiceBus.ExceptionInfo.Source

The exception source.

NServiceBus.ExceptionInfo.StackTrace

The exception stack trace.

Example error headers

Given an initiating message with the following headers:

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 2fc7ccd9-415f-43dc-ab5c-b33e0182dd3c
NServiceBus.CorrelationId = 0817844c-2f74-4aa4-85d0-b33e0182dd3c
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 0817844c-2f74-4aa4-85d0-b33e0182dd3c
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterError
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterError
NServiceBus.TimeSent = 2025-08-19 23:28:31:766746 Z
NServiceBus.Version = 9.2.7

when that message fails to be processed, it will be sent to the error queue with the following headers:

$.diagnostics.hostdisplayname = MACHINENAME
$.diagnostics.hostid = 7f787fc8e0611a3fab8a93c8767f6639
$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 2fc7ccd9-415f-43dc-ab5c-b33e0182dd3c
NServiceBus.CorrelationId = 0817844c-2f74-4aa4-85d0-b33e0182dd3c
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.ExceptionInfo.Data.Handler canceled = False
NServiceBus.ExceptionInfo.Data.Handler failure time = 2025-08-19 23:28:31:799078 Z
NServiceBus.ExceptionInfo.Data.Handler start time = 2025-08-19 23:28:31:798988 Z
NServiceBus.ExceptionInfo.Data.Handler type = Core.Headers.Writers.MyNamespace.MessageHandler
NServiceBus.ExceptionInfo.Data.Message ID = 0817844c-2f74-4aa4-85d0-b33e0182dd3c
NServiceBus.ExceptionInfo.Data.Message type = Core.Headers.Writers.MyNamespace.MessageToSend
NServiceBus.ExceptionInfo.Data.Pipeline canceled = False
NServiceBus.ExceptionInfo.Data.Transport message ID = 4f340bea-c068-4275-9d85-f613a14ebd33
NServiceBus.ExceptionInfo.ExceptionType = System.Exception
NServiceBus.ExceptionInfo.HelpLink = 
NServiceBus.ExceptionInfo.Message = The exception message from the handler.
NServiceBus.ExceptionInfo.Source = Core_9
NServiceBus.ExceptionInfo.StackTrace = System.Exception: The exception message from the handler.
      at Core.Headers.Writers.HeaderWriterError.MessageHandler.Handle(MessageToSend message, IMessageHandlerContext context)
      at NServiceBus.Pipeline.MessageHandler.Invoke(Object message, IMessageHandlerContext handlerContext)
      at NServiceBus.InvokeHandlerTerminator.Terminate(IInvokeHandlerContext context)
      at NServiceBus.LoadHandlersConnector.Invoke(IIncomingLogicalMessageContext context, Func2 stage)
      at NServiceBus.DeserializeMessageConnector.Invoke(IIncomingPhysicalMessageContext context, Func2 stage)
      at NServiceBus.ProcessingStatisticsBehavior.Invoke(IIncomingPhysicalMessageContext context, Func2 next)
      at NServiceBus.TransportReceiveToPhysicalMessageConnector.Invoke(ITransportReceiveContext context, Func2 next)
      at NServiceBus.RetryAcknowledgementBehavior.Invoke(ITransportReceiveContext context, Func2 next)
      at NServiceBus.MainPipelineExecutor.Invoke(MessageContext messageContext, CancellationToken cancellationToken)
      at NServiceBus.MainPipelineExecutor.Invoke(MessageContext messageContext, CancellationToken cancellationToken)
      at NServiceBus.LearningTransportMessagePump.ProcessFile(ILearningTransportTransaction transaction, String messageId, CancellationToken messageProcessingCancellationToken)
NServiceBus.FailedQ = HeaderWriterError
NServiceBus.MessageId = 0817844c-2f74-4aa4-85d0-b33e0182dd3c
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterError
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ProcessingEndpoint = HeaderWriterError
NServiceBus.ProcessingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterError
NServiceBus.TimeOfFailure = 2025-08-19 23:28:31:799804 Z
NServiceBus.TimeSent = 2025-08-19 23:28:31:766746 Z
NServiceBus.Version = 9.2.7

Encryption headers

Headers when using message property encryption.

NServiceBus.RijndaelKeyIdentifier

Identifies the encryption key used for encryption of the message property fragments.

Example headers

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 32741e62-c43b-4a60-aaec-b33e0182dd31
NServiceBus.CorrelationId = d5071b46-a89e-4837-b56f-b33e0182dd31
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = d5071b46-a89e-4837-b56f-b33e0182dd31
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterEncryption
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterEncryption
NServiceBus.TimeSent = 2025-08-19 23:28:31:733137 Z
NServiceBus.Version = 9.2.7

Example body

{"EncryptedProperty1":"String 1","EncryptedProperty2":"String 2"}

File share data bus headers

When using the file share data bus, extra headers and serialized message information are necessary to correlate between the information on the queue and the data on the file system.

Using DataBusProperty

When using the DataBusProperty, NServiceBus uses that property as a placeholder at serialization time. The serialized value of that property will contain a key. This key maps to a named header. That header then provides the path suffix of where that binary data is stored on disk on the file system.

The payload content-type is captured in the header NServiceBus.DataBusConfig.ContentType.

Example headers

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = 25174c1e-ced3-4fbf-977a-b33e0182dbd6
NServiceBus.CorrelationId = 7035b704-6873-4940-be7b-b33e0182dbd5
NServiceBus.DataBus.2025-08-19_23/1525d628-b59a-41fe-a9cb-7245faa42c24 = 2025-08-19_23/1525d628-b59a-41fe-a9cb-7245faa42c24
NServiceBus.DataBus.2025-08-19_23/f5372f63-a5a6-438b-b71d-1e0a7fa42f5f = 2025-08-19_23/f5372f63-a5a6-438b-b71d-1e0a7fa42f5f
NServiceBus.DataBusConfig.ContentType = application/json
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 7035b704-6873-4940-be7b-b33e0182dbd5
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterDataBusProperty
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterDataBusProperty
NServiceBus.TimeSent = 2025-08-19 23:28:30:573451 Z
NServiceBus.Version = 9.2.7

Example body

{"LargeProperty1":{"Key":"2025-08-19_23/1525d628-b59a-41fe-a9cb-7245faa42c24","HasValue":true},"LargeProperty2":{"Key":"2025-08-19_23/f5372f63-a5a6-438b-b71d-1e0a7fa42f5f","HasValue":true}}

Using conventions

When using conventions there is no way to store a correlation value inside the serialized property. Instead, each property has a matching header with the property name used as the header suffix. That header then provides the path suffix of where that binary data is stored on disk on the file system.

Example headers

$.diagnostics.originating.hostid = 7f787fc8e0611a3fab8a93c8767f6639
NServiceBus.ContentType = application/json
NServiceBus.ConversationId = b4fd3b02-d711-476f-87d9-b33e0182dbc0
NServiceBus.CorrelationId = 6f18f129-f4f5-4d63-befd-b33e0182dbc0
NServiceBus.DataBus.Core.Headers.Writers.MyNamespace.MessageToSend.LargeProperty1 = 2025-08-19_23/785fdfe2-e670-40dc-8bc4-de17c67c38d7
NServiceBus.DataBus.Core.Headers.Writers.MyNamespace.MessageToSend.LargeProperty2 = 2025-08-19_23/4187b6aa-b879-4915-9e47-4f7c02971364
NServiceBus.DataBusConfig.ContentType = application/json
NServiceBus.EnclosedMessageTypes = Core.Headers.Writers.MyNamespace.MessageToSend, MyAssembly, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null
NServiceBus.MessageId = 6f18f129-f4f5-4d63-befd-b33e0182dbc0
NServiceBus.MessageIntent = Send
NServiceBus.OriginatingEndpoint = HeaderWriterDataBusConvention
NServiceBus.OriginatingMachine = MACHINENAME
NServiceBus.ReplyToAddress = HeaderWriterDataBusConvention
NServiceBus.TimeSent = 2025-08-19 23:28:30:505448 Z
NServiceBus.Version = 9.2.7

Example body

{"LargeProperty1":null,"LargeProperty2":null}

ServiceControl

ServiceControl.RetryTo

Value: Queue name

When present in a failed message to ServiceControl, ServiceControl will send the message to this queue instead of the queue name value from NServiceBus.FailedQ

This is used by the ServiceControl transport adapter to bridge failed messages between different transports.

ServiceControl.TargetEndpointAddress

Value: Queue name

Used by the messaging bridge to return failed messages back to the correct queue

ServiceControl.Retry.AcknowledgementQueue

Value: Queue name

The queue to send an acknowledgement system message back to a specific ServiceControl queue to mark a retried message as processed.

ServiceControl.Retry.Successful

Contains a timestamp in the format yyyy-MM-dd HH:mm:ss:ffffff Z to indicate when a message was succesfully processed after a retry from ServiceControl.

Part of the control message sent to ServiceControl to signal that a message was manually retried in ServicePulse/Control and flagged as processed successfully.

ServiceControl.Retry.UniqueMessageId

Contains the NServiceBus.MessageId value of the successfully processed message.

Part of the control message send back to ServiceControl to signal that a message that was manually retried in ServicePulse/Control and flagged as processed successfully.

The presence of any header key that starts with ServiceControl. indicates that the message has been retried from ServiceControl.

Samples

Related Articles