Skip to main content

Spark Structured Streaming

Prophecy provides native support for streaming data running on Spark Structured Streaming. This documentation assumes you are already familiar with how Structured Streaming works. For more information, you can consult the Structured Streaming documentation here.

Streaming pipelines work differently from batch pipelines:

  1. Streaming applications are always running, continuously processing incoming data.
  2. Data is processed in micro-batches, with the notable exception of Continuous Triggers (an experimental feature available in Spark3.3). Continuous triggers are not supported by Prophecy.
  3. Streaming applications handle transient data rather than maintain the entire data. Aggregations and joins require watermarking for maintaining a limited state.
  4. All Streaming Datasets can behave similarly to Batch datasets using the Spark ForEachBatch, though ForEachBatch is not supported by Prophecy.

The streaming capability is available for Python projects that do not use UC Shared clusters.

Project TypeSpark Cluster Access ModeSpark Cluster TypeStructured Streaming Capability
PythonSingle UserUC, legacySupported as of Prophecy3.4.x
PythonSharedUCNot supported as of Prophecy3.4.x
ScalaAny ModeAny typeNot supported as of Prophecy3.4.x

Spark Structured Streaming using Prophecy IDE

How to Create a Streaming Pipeline Within a Prophecy Python Project, a user can create a Structured Streaming Pipeline using the Streaming(beta) mode.

Working with a Streaming Pipeline

To create a Streaming Pipeline, users can follow a process similar to creating a Batch Pipeline in a Python project. For more on Pipeline creation and understanding Prophecy pipelines, please check this link. Streaming Pipelines work differently from Batch Pipelines in the following ways:

  1. Partial runs are not supported for streaming applications. A partial run is only allowed on a Streaming Target Gem.
  2. Streaming pipelines are long-running tasks and process data at intervals. Currently, they do not capture cumulative statistics.
  3. Streaming Pipelines are continuous and do not stop running. To terminate a Streaming Pipeline, users need to click the "X" button. A Streaming Pipeline is an ongoing process and will not terminate itself.
  4. To deploy the Pipeline on Databricks, users can follow the same process described here. A scheduled Job will check if the Streaming Pipeline is running every X minutes. If the Pipeline is not running, the Job will attempt to start it.

Streaming Sources and Targets

Spark Structured Streaming applications have a variety of source and target components available to construct Piplines.

Streaming source gems render to spark.readStream() on the Spark side. Currently, we support file stream-based sources and targets, warehouse-based targets, and event stream-based sources and targets. For more information on Streaming Source and Target Gems, click here.

Additionally, any batch data sources can be used in a streaming application. Batch data sources are read using the spark.read() function at every processing trigger (due to Spark evaluating lazily). More on triggers here. For more information on Batch Source and Target Gems, click here.

Streaming Transformations

For more information on Streaming Transformations, click here.