What is Apache Beam?
Apache Beam is an open source, unified model for defining both batch and streaming data-parallel processing pipelines. Using one of the open source Beam SDKs, you build a program that defines the pipeline. The pipeline is then executed by one of Beam’s supported distributed processing back-ends, which include Apache Flink, Apache Spark, and Google Cloud Dataflow.
Beam is particularly useful for embarrassingly parallel data processing tasks, in which the problem can be decomposed into many smaller bundles of data that can be processed independently and in parallel. You can also use Beam for Extract, Transform, and Load (ETL) tasks and pure data integration. These tasks are useful for moving data between different storage media and data sources, transforming data into a more desirable format, or loading data onto a new system.
The Beam Pipeline Runners translate the data processing pipeline you define with your Beam program into the API compatible with the distributed processing back-end of your choice. When you run your Beam program, you’ll need to specify an appropriate runner for the back-end where you want to execute your pipeline.
Beam currently supports the following runners:
- Direct
- Apache Flink
- Apache Nemo
- Apache Samza
- Apache Spark
- Google Cloud Dataflow
- Hazelcast Jet
- Twister2
Motivation
Problem with current parallel computing frameworks is that they exptect input data to become complete at some point in time. This is not the case for streaming data. Beam has a unified model for defining both batch (bounded data) and streaming (unbounded data) data-parallel processing pipelines. And it has a different execution engines so it can run on different backends.
Beam Concepts
Windowing:
Enable processing of unbounded data by dividing it into finite chunks (windows) that can be processed independently.
- Fixed windows: Set fixed window size, data is grouped into fixed-size windows based on event timestamp.
- Sliding windows: Set window size and slide period, data from one window may overlap with data from the next window.
- Session windows: Set session timeout, data is grouped into windows based on session timeout. For example, if a user is inactive for more than 10 minutes, the session window expires and the data is processed.
- Global windows: All data is assigned to a single window. Used for batch jobs.
Event Time vs Processing Time:
- Event time: Use the timestamp recorded when the event occurred. E.g. when a user clicks on a button.
- Processing time: Use the timestamp when the event was processed. E.g. when the click is processed by the server.
Triggers:
Define when to produce and output result from the window.
Core Transformations
ParDo:
- Perform a general-purpose transformation on each element.
- Expects a
DoFn
as a parameter. ADoFn
is user define logic that implements the transformation.
- Element-wise transformation.
- Can be applied to unbounded and bounded data.
GroupByKey:
- Group elements by key.
- Collects elements for a given key into a window.