Class SocketDynamicTableSource
- java.lang.Object
-
- org.apache.flink.table.examples.java.connectors.SocketDynamicTableSource
-
- All Implemented Interfaces:
DynamicTableSource
,ScanTableSource
public final class SocketDynamicTableSource extends Object implements ScanTableSource
TheSocketDynamicTableSource
is used during planning.In our example, we don't implement any of the available ability interfaces such as
SupportsFilterPushDown
orSupportsProjectionPushDown
. Therefore, the main logic can be found ingetScanRuntimeProvider(ScanContext)
where we instantiate the requiredSource
and itsDeserializationSchema
for runtime. Both instances are parameterized to return internal data structures (i.e.RowData
).Note: This is only an example and should not be used in production. The source is not fault-tolerant and can only work with a parallelism of 1.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.flink.table.connector.source.DynamicTableSource
DynamicTableSource.Context, DynamicTableSource.DataStructureConverter
-
Nested classes/interfaces inherited from interface org.apache.flink.table.connector.source.ScanTableSource
ScanTableSource.ScanContext, ScanTableSource.ScanRuntimeProvider
-
-
Constructor Summary
Constructors Constructor Description SocketDynamicTableSource(String hostname, int port, byte byteDelimiter, DecodingFormat<DeserializationSchema<RowData>> decodingFormat, DataType producedDataType)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description String
asSummaryString()
Returns a string that summarizes this source for printing to a console or log.DynamicTableSource
copy()
Creates a copy of this instance during planning.ChangelogMode
getChangelogMode()
Returns the set of changes that the planner can expect during runtime.ScanTableSource.ScanRuntimeProvider
getScanRuntimeProvider(ScanTableSource.ScanContext runtimeProviderContext)
Returns a provider of runtime implementation for reading the data.
-
-
-
Constructor Detail
-
SocketDynamicTableSource
public SocketDynamicTableSource(String hostname, int port, byte byteDelimiter, DecodingFormat<DeserializationSchema<RowData>> decodingFormat, DataType producedDataType)
-
-
Method Detail
-
getChangelogMode
public ChangelogMode getChangelogMode()
Description copied from interface:ScanTableSource
Returns the set of changes that the planner can expect during runtime.- Specified by:
getChangelogMode
in interfaceScanTableSource
- See Also:
RowKind
-
getScanRuntimeProvider
public ScanTableSource.ScanRuntimeProvider getScanRuntimeProvider(ScanTableSource.ScanContext runtimeProviderContext)
Description copied from interface:ScanTableSource
Returns a provider of runtime implementation for reading the data.There might exist different interfaces for runtime implementation which is why
ScanTableSource.ScanRuntimeProvider
serves as the base interface. ConcreteScanTableSource.ScanRuntimeProvider
interfaces might be located in other Flink modules.Independent of the provider interface, the table runtime expects that a source implementation emits internal data structures (see
RowData
for more information).The given
ScanTableSource.ScanContext
offers utilities by the planner for creating runtime implementation with minimal dependencies to internal data structures.SourceProvider
is the recommended core interface.SourceFunctionProvider
inflink-table-api-java-bridge
andInputFormatProvider
are available for backwards compatibility.- Specified by:
getScanRuntimeProvider
in interfaceScanTableSource
- See Also:
SourceProvider
-
copy
public DynamicTableSource copy()
Description copied from interface:DynamicTableSource
Creates a copy of this instance during planning. The copy should be a deep copy of all mutable members.- Specified by:
copy
in interfaceDynamicTableSource
-
asSummaryString
public String asSummaryString()
Description copied from interface:DynamicTableSource
Returns a string that summarizes this source for printing to a console or log.- Specified by:
asSummaryString
in interfaceDynamicTableSource
-
-