description |
---|
Step-by-step guide to set up Azure Event Hubs as a destination in RudderStack |
****Azure Event Hubs is a data streaming platform and an event ingestion service. It provides a Kafka endpoint which can be used by your existing Kafka-based applications as an alternative to running your own Kafka clusters.
RudderStack supports Azure Event Hubs as a destination to which you can seamlessly send your event data.
{% hint style="warning" %} RudderStack does not support the Basic tier of Azure Event Hubs. For this integration to work, you need to have a standard tier (or higher) of Event Hubs which includes an Apache Kafka endpoint.
For more information, refer to the Event Hubs' pricing page. {% endhint %}
{% hint style="success" %} Find the open-source transformer code for this destination in our GitHub repo. {% endhint %}
To enable sending data to Azure Event Hubs, you need to add it as a destination in RudderStack. Once the destination is enabled, events from RudderStack will start to flow to Azure Event Hubs.
Before configuring your source and destination in ****RudderStack, check whether the source platform is supported by Azure Event Hubs by referring to the table below:
Connection Mode | Web | Mobile | Server |
---|---|---|---|
Device Mode | - | - | - |
Cloud Mode | Supported | Supported | Supported |
{% hint style="info" %} To know more about the difference between Cloud mode and Device mode in RudderStack, read the RudderStack connection modes guide. {% endhint %}
Once you have confirmed that the platform supports sending events to Azure Event Hubs, perform the steps as mentioned below:
- Choose a source to which you would like to add Azure Event Hubs as a destination.
{% hint style="info" %} Follow our guide on How to Add a Source and Destination in RudderStack to add a source and destination in RudderStack. {% endhint %}
- Select the destination as Azure Event Hubs. Give your destination a name, and then click on Next.
- In the Connection Settings, ****fill the required fields with the relevant information and click Next.
This section lists the required connection settings to configure Event Hubs as a destination in RudderStack.
- Bootstrap server: The bootstrap server information goes here. This is in the format
hostname of your event hub namespace
:port
- Topic Name: The topic name, or the name of the Event Hub ****that you have created in your Azure portal.
- Event Hubs Connection String: Your Event Hubs' primary connection string. For more information, refer to Microsoft's How to get Event hubs connection string guide.
RudderStack uses userId
as the partition key of a given message.
{% hint style="info" %}
If the userId
is not present in the payload, then anonymousId
is used.
{% endhint %}
If you have a multi-partitioned topic, then the records of the same userId
(or anonymousId
in absence of userId
) will always go to the same partition.
The Bootstrap server address is in the following format:
hostname of Event Hub namespace
: port
For example: NAMESPACENAME.servicebus.windows.net:9093
Here NAMESPACENAME
is your event hubs namespace, while 9093
is the port number.
The Topic name is the name of the Event Hub that you have created in your Azure portal.
Event Hubs connection string is the primary connection string of your shared access policy. For more information, refer to Microsoft's How to get Event hubs connection string guide.
Check whether you are using the proper Event Hubs connection string for the policy that you have created.
You need to create a policy to write to the Event Hub with a Send
permission, and put the corresponding primary connection string in the destination settings, as described in the Getting Started section of this guide.
If you come across any issues while configuring or using Azure Event Hubs with RudderStack, feel free to contact us or start a conversation on our Slack channel.