Hello John:

* As for the type superclass, it is mainly for allowing super class serdes.
More details can be found here:
https://cwiki.apache.org/confluence/display/KAFKA/KIP-100+-+Relax+Type+constraints+in+Kafka+Streams+API

* I may have slight preference on reusing existing classes but I think most
of my rationales are quite subjective. Personally I do not find `self
documenting` worth a new class but I can be convinced if people have other
motivations doing it :)


Guozhang


On Tue, May 15, 2018 at 11:19 AM, John Roesler <j...@confluent.io> wrote:

> Thanks for the KIP, Guozhang.
>
> It looks good overall to me; I just have one question:
> * Why do we bound the generics of KVMapper in KStream to be superclass-of-K
> and superclass-of-V instead of exactly K and V, as in Topology? I might be
> thinking about it wrong, but that seems backwards to me. If anything,
> bounding to be a subclass-of-K or subclass-of-V would seem right to me.
>
> One extra thought: I agree that KVMapper<K,V,String /*topic name*/> is an
> applicable type for extracting the topic name, but I wonder what the value
> of reusing the KVMapper for this purpose is. Would defining a new class,
> say TopicNameExtractor<K,V>, provide the same functionality while being a
> bit more self-documenting?
>
> Thanks,
> -John
>
> On Tue, May 15, 2018 at 12:32 AM, Guozhang Wang <wangg...@gmail.com>
> wrote:
>
> > Hello folks,
> >
> > I'd like to start a discussion on adding dynamic routing functionality in
> > Streams sink node. I.e. users do not need to specify the topic name at
> > compilation time but can dynamically determine which topic to send to
> based
> > on each record's key value pairs. Please find a KIP here:
> >
> > https://cwiki.apache.org/confluence/display/KAFKA/KIP-
> > 303%3A+Add+Dynamic+Routing+in+Streams+Sink
> >
> > Any feedbacks are highly appreciated.
> >
> > Thanks!
> >
> > -- Guozhang
> >
>



-- 
-- Guozhang

Reply via email to