This is the source code of the Azure Event Hubs Connector for Apache Spark.
Azure Event Hubs is a highly scalable publish-subscribe service that can ingest millions of events per second and stream them into multiple applications.
Spark Streaming and Structured Streaming are scalable and fault-tolerant stream processing engines that allow users to process huge amounts of data using
complex algorithms expressed with high-level functions like map
, reduce
, join
, and window
. This data can then be pushed to
filesystems, databases, or even back to Event Hubs.
By making Event Hubs and Spark easier to use together, we hope this connector makes building scalable, fault-tolerant applications easier for our users.
There is an open issue for each planned feature/enhancement.
We maintain an FAQ - reach out to us via gitter if you think anything needs to be added or clarified!
For Scala/Java applications using SBT/Maven project definitions, link your application with the artifact below. Note: See Latest Releases to find the correct artifact for your version of Apache Spark (or Databricks)!
groupId = com.microsoft.azure
artifactId = azure-eventhubs-spark_2.11
version = 2.3.21
or
groupId = com.microsoft.azure
artifactId = azure-eventhubs-spark_2.12
version = 2.3.21
Documentation for our connector can be found here. The integration guides there contain all the information you need to use this library.
If you're new to Apache Spark and/or Event Hubs, then we highly recommend reading their documentation first. You can read Event Hubs documentation here, documentation for Spark Streaming here, and, the last but not least, Structured Streaming here.
If you need additional assistance, please don't hesitate to ask! General questions and discussion should happen on our gitter chat. Please open an issue for bug reports and feature requests! Feedback, feature requests, bug reports, etc are all welcomed!
If you'd like to help contribute (we'd love to have your help!), then go to our Contributor's Guide for more information.
In order to use the connector, you need to have:
- Java 1.8 SDK installed
- Maven 3.x installed (or SBT version 1.x)
More details on building from source and running tests can be found in our Contributor's Guide.
// Builds jar and runs all tests
mvn clean package
// Builds jar, runs all tests, and installs jar to your local maven repository
mvn clean install