Flink is able to process streaming data based on different notions of time.
Processing time refers to the system time of the machine (also known as “wall-clock time”) that is executing the respective operation.
Event time refers to the processing of streaming data based on timestamps which are attached to each row. The timestamps can encode when an event happened.
Ingestion time is the time that events enter Flink; internally, it is treated similarly to event time.
For more information about time handling in Flink, see the introduction about Event Time and Watermarks.
This page explains how time attributes can be defined for time-based operations in Flink’s Table API & SQL.
Time-based operations such as windows in both the Table API and SQL require information about the notion of time and its origin. Therefore, tables can offer logical time attributes for indicating time and accessing corresponding timestamps in table programs.
Time attributes can be part of every table schema. They are defined when creating a table from a CREATE TABLE DDL or a DataStream or are pre-defined when using a TableSource. Once a time attribute has been defined at the beginning, it can be referenced as a field and can be used in time-based operations.
As long as a time attribute is not modified and is simply forwarded from one part of the query to another, it remains a valid time attribute. Time attributes behave like regular timestamps and can be accessed for calculations. If a time attribute is used in a calculation, it will be materialized and becomes a regular timestamp. Regular timestamps do not cooperate with Flink’s time and watermarking system and thus can not be used for time-based operations anymore.
Table programs require that the corresponding time characteristic has been specified for the streaming environment:
Processing time
Processing time allows a table program to produce results based on the time of the local machine. It is the simplest notion of time but does not provide determinism. It neither requires timestamp extraction nor watermark generation.
There are three ways to define a processing time attribute.
Defining in create table DDL
The processing time attribute is defined as a computed column in create table DDL using the system PROCTIME() function. Please see CREATE TABLE DDL for more information about computed column.
During DataStream-to-Table Conversion
The processing time attribute is defined with the .proctime property during schema definition. The time attribute must only extend the physical schema by an additional logical field. Thus, it can only be defined at the end of the schema definition.
Using a TableSource
The processing time attribute is defined by a TableSource that implements the DefinedProctimeAttribute interface. The logical time attribute is appended to the physical schema defined by the return type of the TableSource.
Event time
Event time allows a table program to produce results based on the time that is contained in every record. This allows for consistent results even in case of out-of-order events or late events. It also ensures replayable results of the table program when reading records from persistent storage.
Additionally, event time allows for unified syntax for table programs in both batch and streaming environments. A time attribute in a streaming environment can be a regular field of a record in a batch environment.
In order to handle out-of-order events and distinguish between on-time and late events in streaming, Flink needs to extract timestamps from events and make some kind of progress in time (so-called watermarks).
An event time attribute can be defined either in create table DDL or during DataStream-to-Table conversion or by using a TableSource.
Defining in create table DDL
The event time attribute is defined using WATERMARK statement in CREATE TABLE DDL. A watermark statement defines a watermark generation expression on an existing event time field, which marks the event time field as event time attribute. Please see CREATE TABLE DDL for more information about watermark statement and watermark strategies.
During DataStream-to-Table Conversion
The event time attribute is defined with the .rowtime property during schema definition. Timestamps and watermarks must have been assigned in the DataStream that is converted.
There are two ways of defining the time attribute when converting a DataStream into a Table. Depending on whether the specified .rowtime field name exists in the schema of the DataStream or not, the timestamp field is either
appended as a new field to the schema or
replaces an existing field.
In either case the event time timestamp field will hold the value of the DataStream event time timestamp.
Using a TableSource
The event time attribute is defined by a TableSource that implements the DefinedRowtimeAttributes interface. The getRowtimeAttributeDescriptors() method returns a list of RowtimeAttributeDescriptor for describing the final name of a time attribute, a timestamp extractor to derive the values of the attribute, and the watermark strategy associated with the attribute.
Please make sure that the DataStream returned by the getDataStream() method is aligned with the defined time attribute.
The timestamps of the DataStream (the ones which are assigned by a TimestampAssigner) are only considered if a StreamRecordTimestamp timestamp extractor is defined.
Watermarks of a DataStream are only preserved if a PreserveWatermarks watermark strategy is defined.
Otherwise, only the values of the TableSource’s rowtime attribute are relevant.