Package org.apache.iceberg.flink.sink
Class FlinkSink.Builder
java.lang.Object
org.apache.iceberg.flink.sink.FlinkSink.Builder
- Enclosing class:
- FlinkSink
-
Method Summary
Modifier and TypeMethodDescriptionorg.apache.flink.streaming.api.datastream.DataStreamSink<Void>append()Append the iceberg sink operators to write records to iceberg table.Configure the writeDistributionModethat the flink sink will use.equalityFieldColumns(List<String> columns) Configuring the equality field columns for iceberg table that accept CDC or UPSERT events.flinkConf(org.apache.flink.configuration.ReadableConfig config) overwrite(boolean newOverwrite) Set the write properties for Flink sink.Set the write properties for Flink sink.setSnapshotProperties(Map<String, String> properties) setSnapshotProperty(String property, String value) tableLoader(TableLoader newTableLoader) The table loader is used for loading tables inIcebergFilesCommitterlazily, we need this loader becauseTableis not serializable and could not just use the loaded table from Builder#table in the remote task manager.tableSchema(org.apache.flink.table.api.TableSchema newTableSchema) Set the uid prefix for FlinkSink operators.upsert(boolean enabled) All INSERT/UPDATE_AFTER events from input stream will be transformed to UPSERT events, which means it will DELETE the old records and then INSERT the new records.writeParallelism(int newWriteParallelism) Configuring the write parallel number for iceberg stream writer.
-
Method Details
-
table
This icebergTableinstance is used for initializingIcebergStreamWriterwhich will write all the records intoDataFiles and emit them to downstream operator. Providing a table would avoid so many table loading from each separate task.- Parameters:
newTable- the loaded iceberg table instance.- Returns:
FlinkSink.Builderto connect the iceberg table.
-
tableLoader
The table loader is used for loading tables inIcebergFilesCommitterlazily, we need this loader becauseTableis not serializable and could not just use the loaded table from Builder#table in the remote task manager.- Parameters:
newTableLoader- to load iceberg table inside tasks.- Returns:
FlinkSink.Builderto connect the iceberg table.
-
set
Set the write properties for Flink sink. View the supported properties inFlinkWriteOptions -
setAll
Set the write properties for Flink sink. View the supported properties inFlinkWriteOptions -
tableSchema
-
overwrite
-
flinkConf
-
distributionMode
Configure the writeDistributionModethat the flink sink will use. Currently, flink supportDistributionMode.NONEandDistributionMode.HASH.- Parameters:
mode- to specify the write distribution mode.- Returns:
FlinkSink.Builderto connect the iceberg table.
-
writeParallelism
Configuring the write parallel number for iceberg stream writer.- Parameters:
newWriteParallelism- the number of parallel iceberg stream writer.- Returns:
FlinkSink.Builderto connect the iceberg table.
-
upsert
All INSERT/UPDATE_AFTER events from input stream will be transformed to UPSERT events, which means it will DELETE the old records and then INSERT the new records. In partitioned table, the partition fields should be a subset of equality fields, otherwise the old row that located in partition-A could not be deleted by the new row that located in partition-B.- Parameters:
enabled- indicate whether it should transform all INSERT/UPDATE_AFTER events to UPSERT.- Returns:
FlinkSink.Builderto connect the iceberg table.
-
equalityFieldColumns
Configuring the equality field columns for iceberg table that accept CDC or UPSERT events.- Parameters:
columns- defines the iceberg table's key.- Returns:
FlinkSink.Builderto connect the iceberg table.
-
uidPrefix
Set the uid prefix for FlinkSink operators. Note that FlinkSink internally consists of multiple operators (like writer, committer, dummy sink etc.) Actually operator uid will be appended with a suffix like "uidPrefix-writer".
If provided, this prefix is also applied to operator names.
Flink auto generates operator uid if not set explicitly. It is a recommended best-practice to set uid for all operators before deploying to production. Flink has an option topipeline.auto-generate-uid=falseto disable auto-generation and force explicit setting of all operator uid.
Be careful with setting this for an existing job, because now we are changing the operator uid from an auto-generated one to this new value. When deploying the change with a checkpoint, Flink won't be able to restore the previous Flink sink operator state (more specifically the committer operator state). You need to use--allowNonRestoredStateto ignore the previous sink state. During restore Flink sink state is used to check if last commit was actually successful or not.--allowNonRestoredStatecan lead to data loss if the Iceberg commit failed in the last completed checkpoint.- Parameters:
newPrefix- prefix for Flink sink operator uid and name- Returns:
FlinkSink.Builderto connect the iceberg table.
-
setSnapshotProperties
-
setSnapshotProperty
-
toBranch
-
append
Append the iceberg sink operators to write records to iceberg table.- Returns:
DataStreamSinkfor sink.
-