views:

348

answers:

3

Is it possible to guarantee ordered delivery when using WCF netMSMQbinding?

We are putting an insert command followed by a number of update commands on the same queue, and occassionally one of the updates beats the insert.

Having added extensive logging it is clear that they are being added to the queue in the correct order and being processed in a different order.

I have managed to Google a couple of articles that state that this behaviour is expected, but it seems like it must be possible to configure it to be ordered somehow.

Our queues are transactional, so I don't think that adding sequence numbers and resequencing at the destination is going to work, as that would lose out transactionality

If I add the attribute [DeliveryRequirements(RequireOrderedDelivery=true, QueuedDeliveryRequirements=QueuedDeliveryRequirementsMode.Require)] I get the following error:

The DeliveryRequirementsAttribute on contract 'IService' specifies a QueuedDeliveryRequirements value of NotAllowed. However, the configured binding for this contract specifies that it does support queued delivery. A queued binding may not be used with this contract.

I have no idea why we get this error, as everything "appears" to be setup correctly. I haven't managed to find any confirmation that this setting is allowed for MSMQ though, as it appears to be a WS-RM setting, and AFAIK netMSMQBinding does not support WS-RM.

+1  A: 

MSMQ does not support ordered delivery, hence you can not.

Take a look at System.ServiceModel.Channels.MsmqBindingElementBase+BindingDeliveryCapabilitiesHelper which is the class specifying MSMQ's binding capabilities, and how it implements that property:

bool IBindingDeliveryCapabilities.AssuresOrderedDelivery
{
    get
    {
        return false;
    }
}
Krzysztof Koźmic
Perfect. Just the definitve answer I was looking for. I can get back to the day job now :)
Modan
A: 

Looks like you can group messages, so therefore you could specify the order in the contract. Check out this MSDN article on grouping messages.

Adam Fyles
+1  A: 

This post from Simon Gittins looks like it suggests that ordered delivery is possible:

As it turns out, there's an undocumented feature that deals with this situation:

  • Apply a TransactedBatchingBehavior with a batch size of ONE to the service endpoint.
  • ReleaseServiceInstanceOnTransactionComplete must be set to true on the service implementation.

Once these two things are done, my test program no longer produces out of order messages.

Drew Noakes