Collect data from Azure Event Hubs
Most recent version: v1.0.1
This is a Pull Listener and therefore should not be used in environments with more than one cluster.
Overview
Onum supports integration with Azure Event Hubs
The Azure Event Hubs Listener receives messages from an Azure Event Hub for real-time data streaming, providing support for message batching, retries, and secure connection options.
Prerequisites
In order to use this Listener, you must activate the Environment Variable in your distributor using docker compose (AZURE_EVENTHUB_LISTENER_EXECUTION_ENABLED
)
Azure Event Hubs Setup
There are various management credentials that Onum needs to communicate with the event hub.
Event Hubs namespace
Event hub
See the Azure Event Hubs documentation for how to create these.
Onum Setup
Log in to your Onum tenant and click Listeners > New listener.


Double-click the Azure Event Hubs Listener.


Enter a Name for the new Listener. Optionally, add a Description and some Tags to identify the Listener.


Establish the Event Hub Connection
Enter the Event Hub Namespace* to connect to (e.g.
my-namespace.servicebus.windows.net
). You can find this in the top left-hand corner of you Azure area.In your Azure console, click your Event Hubs namespace to view the Hubs it contains in the middle pane and enter it in the Event Hub Name* field. Alternatively, click Event Hub to create one.
In the left-hand menu, scroll down to Entities and click Consumer groups to see the names. This value is
$Default
when empty.In the left-hand menu, scroll down to Entities and click Consumer groups to see the names. This value is
$Default
when empty.


In the Authentication section, choose between Connection String and Entra ID as the Authentication Type.
Connection String
Connection String* The URL for your Event Hub. To get it:
Click your Event Hubs namespace to view the Hubs it contains.
Scroll down to the bottom and click the specific event hub to connect to.
In the left menu, go to Shared Access Policies.
If there is no policy created for an event hub, create one with Manage, Send, or Listen access.
Select the policy from the list.
Select the copy button next to the Connection string-primary key field.
Depending on the version of Azure you are using, the corresponding field may have a different name, so to help you find it, look for a string with the same format:
Endpoint=sb://.servicebus.windows.net/; SharedAccessKeyName=RootManageSharedAccessKey; SharedAccessKey=
Entra ID - enter the following credentials from the Certificates & Secrets area
Tenant ID*
Client ID*
Client Secret*
Open the Secret fields and click New secret to create a new one:
Give the token a Name.
Turn off the Expiration date option.
Click Add new value and paste the secret corresponding to the JWT token you generated before. Remember that the token will be added in the Zscaler configuration.
Click Save.


Learn more about secrets in Onum in this article.
You can now select the secret you just created in the corresponding fields.


Checkpointing & Processor
When multiple consumer instances read from the same Event Hub and consumer group, a cooperative processor coordinates partition ownership and progress using a checkpoint store (Azure Blob Storage).
Ensures at-least-once processing without duplicates when instances restart: committed checkpoints allow new owners to resume from the last processed offset instead of re-reading the whole partition.
Evenly distributes partitions across active instances (load balancing): with the
balanced
strategy, ownership is redistributed as instances join/leave;greedy
tries to acquire as many partitions as possible.Enables safe horizontal scaling: adding instances increases throughput by processing multiple partitions in parallel.
Learn more in the Azure Event Hubs documentation:
It is recommended you only choose False if you are sure that your worker only uses a single distributor. If you suspect your worker is connected to more than one distributor, it is important to select true and configure the fields below.
Enter the Storage Container Name* In the left-hand menu, scroll down to Resource groups, where you will see a list of all the storage containers within your Event Hub. In Onum, enter the name of the blob container to persist checkpoints and ownership.
Then, configure the Processor Options.
Load Balancing Strategy
Choose how to distribute the work evenly across the server to avoid overload.
Balanced - distributes load evenly across all servers.
Greedy - assigns each new task immediately to the currently leadt-loaded server.
Update Interval (ms) How often a processor renews partition ownership; defaults to 10000ms if unset.
Partition Expiration Duration (ms) Enter a time limit in milliseconds, after which the load partition will be considered expired and can be claimed by other instances.


Decide whether to Use batch settings.
When false, the handler processes events one-by-one using internal defaults (maxBatchSize=1
, maxWaitTimeMs=500
). When true, batch processing settings apply.
Max Batch Size* Enter the maximum bytes for the batch.
Max Wait Time* Enter the maximum amount of milliseconds to wait before considering the batch as complete.


Add the Backoff Settings regarding how long to wait before retrying a request after failure.
Error Backoff (ms) Enter the amount of milliseconds to wait after an error before retrying.
Idle Backoff (ms) Enter the amount of milliseconds to wait before trying again to send a request.


Choose the Decompression method used to restore a compressed message to its original form before being processed (none, gzip or zlib)
Choose the Split Strategy method of dividing the data or requests from the following delimiter options:
None to ignore
Newline
JSON array
JSON object
Custom Delimiter
Custom Delimiter - enter your custom delimiter here.


Finally, click Create labels. Optionally, you can set labels to be used for internal Onum routing of data. By default, data will be set as Unlabeled. Click Create listener when you're done.
Learn more about labels in this article.


Click Create listener when you're done.
Last updated
Was this helpful?