Ordered Delivery with netMSMQbinding

[亡魂溺海] 提交于 2019-12-22 06:41:56

问题


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:


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;
    }
}



回答2:


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.




回答3:


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



来源:https://stackoverflow.com/questions/729612/ordered-delivery-with-netmsmqbinding

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!