Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Using ReceiveMode.PeekLock on the service bus #38

Open
jcono opened this issue Jun 18, 2021 · 1 comment
Open

Using ReceiveMode.PeekLock on the service bus #38

jcono opened this issue Jun 18, 2021 · 1 comment

Comments

@jcono
Copy link
Contributor

jcono commented Jun 18, 2021

I will let you know once I have tested but it's my understanding that the combination of ReceiveMode.PeekLock and MessageHandlerOptions.AutoComplete used when registering the message handler will result in SubscriptionClient.CompleteAsync being called once the handler successfully completes.

The source code for the message pump used by the subscription client would suggest this is the case too.

So as far as I can tell the message would be deleted from the queue so long as the registered handler doesn't throw an exception. At least that's how the comments in the code read (the Microsoft documentation is a little light on detail).

What I don't know yet is what happens in the event of an exception in the handler (meaning the message remains on the queue) and whether that message then gets delivered again (to the same receiver) once the peek lock is abandoned. For our usage I'm hoping it does.

Originally posted by @jcono in #37 (comment)

@jcono
Copy link
Contributor Author

jcono commented Jun 18, 2021

Just following up with a bit more information.

This turns out to be harder than I'd hoped which might have more to do with the architecture of Foundatio MessageBus abstraction than anything else so I'm wondering if there's a way forward.

Using PeekLock doesn't create any problems at all it's just that any exception thrown by a handler registered using IMessageBus.SubscribeAsync is wrapped by the framework (I think to support its abstraction).

Specifically in this case the handler that runs when a message is received on the service bus is in AzureServiceBusMessageBus.OnMessageAsync which in turns hands it off to the MessageBusBase.SendMessageToSubscribers . The problem is that this method is responsible for sending the message to all subscribers and launches that work asynchronously and returns. This means that none of the subscriber handlers have a chance to throw an exception. Either way, currently any exception is swallowed (and logged) by the task that is run.

I think means that the underlying framework would need to change. My apologies as I'm not that familiar with it all yet but perhaps some option in SharedMessageBusOptions to distribute messages synchronously (and not swallow the exception)? That might allow the SendMessageToSubscribers method to be reworked to run the handlers in sequence and have any exception propagate up?

If I have time I might create a PR for this but will probably wait to hear any thoughts first.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant