Tzu-Li (Gordon) Tai created FLINK-16396:
-------------------------------------------

             Summary: Support binding Kafka egresses with YAML-ized modules
                 Key: FLINK-16396
                 URL: https://issues.apache.org/jira/browse/FLINK-16396
             Project: Flink
          Issue Type: New Feature
          Components: Stateful Functions
    Affects Versions: statefun-1.1
            Reporter: Tzu-Li (Gordon) Tai
            Assignee: Tzu-Li (Gordon) Tai


For a full multi-language story in Stateful Functions, we're still lacking a 
YAML-ized way to bind egresses. We should start with a Kafka one, as that is 
the currently only supported ingress for multi-language applications.

We propose to initially add a more "manual" approach for this, which gives the 
user full freedom on partitioning and record serialization.
A more specialized egress with built-in routing / protobuf serialization can 
maybe be added in the future once we collect more knowledge on usage from users.

The plan is as follows:

* Add a {{KafkaProducerRecord}} protobuf message with schema:
{code}
message KafkaProducerRecord {
    string topic
    string key
    bytes valueBytes
}
{code}
How the value was serialized would be completely user-space; the bytes are 
written as is to Kafka. Partitioning depends on the partitioner used by the 
Kafka client, which may be configured with Kafka properties via YAML.

* The Flink sink provider for this egress should expect only messages of 
{{KafkaProducerRecord}} (wrapped within a protobuf Any). It simply transforms 
the information in the received {{KafkaProducerRecord}} to Kafka's own 
{{ProducerRecord}}, and writes that to Kafka.



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to