This post was most recently updated on June 13th, 2022.
2 min read.One more article before Christmas! đ This time, Iâll be fixing a function thatâs triggering based on new messages received through my IoT Hub in my Azure Functions project. Technically speaking, this is super simple to implement â your function needs to define an IoTHubTrigger, with an Event Hub name and usually a Connection String (I donât know why Iâm Sentence Casing that, too, but Iâll stick to it!)
You can tap a practically unlimited number of Azure Function triggers to any Event Hubs (or Azure IoT Hubs), right? Well â yeah, thatâs what it looks like, but actually, you canât. Not without an additional configuration step, that is!
But before getting into the configuration, letâs take a better look at the actual error weâre running into!
Problem
So while trying to run your Azure Functions project with debugging enabled, youâll run into an annoying issue where the function fails to start and throws an error somewhat like the below:
[2021-07-02T09:55:05.076Z] EventProcessorHost error (Action='Checking Leases', HostName='8cc55fad-d313-434d-b663-2b96bbc9efa1', PartitionId='1'). [2021-07-02T09:55:05.078Z] Microsoft.WindowsAzure.Storage: Server encountered an internal error. Please try again after some time. [2021-07-02T09:55:08.673Z] Host lock lease acquired by instance ID '000000000000000000000000D3CDE7D8'.
Or in the CLI itself:
What do?
Reason
Your Azure Functions are trying to tap into an IoT Hub to fire on an EventHubTrigger â and failing due to a conflict in Consumer Groups. See â each Azure Function trigger essentially needs a separate Consumer Group.
Yeah, itâs an absolutely abysmal error message. But thatâs ok â youâre here now, and Iâve got the solution! ;)
Actually, Iâve got 2 solutions (because it could also be your storage emulator messing up). So listen up.
Solution
Below, Iâm outlining the steps that have always helped me to fix this particular issue. The first step is just to restart your Azure Storage Emulator/Explorer (if youâre using one), and if that doesnât help, (re)configure your IoT Hubâs Consumer Groups.
That said, letâs get to it!
Time needed:Â 30 minutes
How to fix âMicrosoft.WindowsAzure.Storage: Server encountered an internal error.â?
- Restart your Azure Storage Explorer
Letâs get the obvious one first â if this works, you donât need to go through all the rest of the steps!
If your Azure Storage Explorer (or Azurite, if thatâs what youâre using) is borked, restart it. Maybe itâll fix the issue and youâll be good!
It didnât? Thought it might not â check out the next steps, then! - Create a new Consumer Group for your Iot Hub
Navigate to Azure IoT Hub, and âBuilt-in Endpointsâ under it. On that blade/tab, you should see something like below â create a new consumer group by entering a new alphanumeric value (hyphens supported) in the field and saving the changes.
- Add a new application setting for your Consumer Group
Now youâll need to tell your Azure Function the name of the consumer group you want it to use.
Something like this:"Values": {
"AzureIoTHubConsumerGroupName": "MyCustomConsumerGroup"
} - Add the âConsumerGroupâ parameter to your trigger (if it doesnât exist already)
In code, this will look somewhat like the below:
public static Task Run(
[IoTHubTrigger("events",
Connection = "EventHubConnectionAppSetting",
ConsumerGroup = "%AzureIoTHubConsumerGroupName%"
)] EventData myEventHubMessage)
And that should be it! Did it resolve your issue? Still, having issues? Let me know in the comments -section below!
References
- https://github.com/Azure/azure-functions-eventhubs-extension/issues/4
- https://www.codewithadam.com/trigger-azure-functions-on-event-hub/
- https://stackoverflow.com/questions/66043636/azure-iot-hub-azure-function-consumer-group-issue
- Donât assign root domain to GitHub Pages if you use it for email! - January 14, 2025
- Experiences from migrating to Bitwarden - January 7, 2025
- 2024 Year Review â and 20 years in business! - December 31, 2024