Choose a real-time message ingestion technology in Azure
Real time processing deals with streams of data that are captured in real-time and processed with minimal latency. Many real-time processing solutions need a message ingestion store to act as a buffer for messages, and to support scale-out processing, reliable delivery, and other message queuing semantics.
What are your options for real-time message ingestion?
Azure Event Hubs
Azure Event Hubs is a highly scalable data streaming platform and event ingestion service, capable of receiving and processing millions of events per second. Event Hubs can process and store events, data, or telemetry produced by distributed software and devices. Data sent to an event hub can be transformed and stored using any real-time analytics provider or batching/storage adapters. Event Hubs provides publish-subscribe capabilities with low latency at massive scale, which makes it appropriate for big data scenarios.
Azure IoT Hub
Azure IoT Hub is a managed service that enables reliable and secure bidirectional communications between millions of IoT devices and a cloud-based back end.
Features of IoT Hub include:
- Multiple options for device-to-cloud and cloud-to-device communication. These options include one-way messaging, file transfer, and request-reply methods.
- Message routing to other Azure services.
- Queryable store for device metadata and synchronized state information.
- Secure communications and access control using per-device security keys or X.509 certificates.
- Monitoring of device connectivity and device identity management events.
In terms of message ingestion, IoT Hub is similar to Event Hubs. However, it was specifically designed for managing IoT device connectivity, not just message ingestion. For more information, see Comparison of Azure IoT Hub and Azure Event Hubs.
Kafka on HDInsight
Apache Kafka is an open-source distributed streaming platform that can be used to build real-time data pipelines and streaming applications. Kafka also provides message broker functionality similar to a message queue, where you can publish and subscribe to named data streams. It is horizontally scalable, fault-tolerant, and extremely fast. Kafka on HDInsight provides a Kafka as a managed, highly scalable, and highly available service in Azure.
Some common use cases for Kafka are:
- Messaging. Because it supports the publish-subscribe message pattern, Kafka is often used as a message broker.
- Activity tracking. Because Kafka provides in-order logging of records, it can be used to track and re-create activities, such as user actions on a web site.
- Aggregation. Using stream processing, you can aggregate information from different streams to combine and centralize the information into operational data.
- Transformation. Using stream processing, you can combine and enrich data from multiple input topics into one or more output topics.
Key selection criteria
To narrow the choices, start by answering these questions:
Do you need two-way communication between your IoT devices and Azure? If so, choose IoT Hub.
Do you need to manage access for individual devices and be able to revoke access to a specific device? If yes, choose IoT Hub.
The following tables summarize the key differences in capabilities.
|Capability||IoT Hub||Event Hubs||Kafka on HDInsight|
|Device-initiated file upload||Yes||No||No|
|Device state information||Device twins||No||No|
|Protocol support||MQTT, AMQP, HTTPS 1||AMQP, HTTPS, Kafka Protocol||Kafka Protocol|
|Security||Per-device identity; revocable access control.||Shared access policies; limited revocation through publisher policies.||Authentication using SASL; pluggable authorization; integration with external authentication services supported.|
 You can also use Azure IoT protocol gateway as a custom gateway to enable protocol adaptation for IoT Hub.
This article is maintained by Microsoft. It was originally written by the following contributors.
- Zoiner Tejada | CEO and Architect
For more information, see Comparison of Azure IoT Hub and Azure Event Hubs.
Submit and view feedback for