Il Gio 29 Feb 2024, 08:46 PengHui Li <peng...@apache.org> ha scritto:

> +1 for the motivation
>
> We should not create partitioned topics when calling
> `pulsarClient.getPartitionsForTopic`
>
> The tricky part is the broker doesn't know if the partition metadata
> getting request is from create produce/consumer or just from
> pulsarClient.getPartitionsForTopic(topicName).
>
> We can follow the same way that Admin API does to have a field
> `createIfAutoCreationEnabled` in the `CommandPartitionedTopicMetadata`
>
> The producer/consumer will set this flag to true to create partitioned
> topics if topic auto-creation is enabled.
> We will use false as the default value.
>


We should bump the protocol version of we change the default behaviour.
This is a wire protocol thing, not about the Java client.

We shuold assume that it is true if not set.
 if we detect that he client is using a newer version of the protocol then
the default is false.

We cannot break old clients


Enrico


> Regards,
> Penghui
>
> On Thu, Feb 29, 2024 at 11:05 AM Yubiao Feng
> <yubiao.f...@streamnative.io.invalid> wrote:
>
> > Hi all
> >
> > ### Background
> > - When calling `pulsarClient.getPartitionsForTopic(topicName)`, Pulsar
> will
> > automatically create the partitioned topic metadata if it does not exist,
> > either using `HttpLookupService` or `BinaryProtoLookupService`.
> > - The partitioned topic auto-creation is dependent on
> > `pulsarClient.getPartitionsForTopic`
> >   - It triggers partitioned metadata creation by
> > `pulsarClient.getPartitionsForTopic`
> >   - And triggers the topic partition creation by producers' registration
> > and consumers' registration.
> >
> > ### Issue
> > Since the method `pulsarClient.getPartitionsForTopic` is a public API,
> and
> > it is named `getxxx,` it should edit nothing.
> >
> > ### Solution
> > - Solution-1: remove the public API `pulsarClient.getPartitionsForTopic`
> > and only use it internally.
> > - Solution-2: provide an internal API to trigger partitioned metadata
> > creation and make the public API `pulsarClient.getPartitionsForTopic`
> edit
> > nothing.
> > - Solution-3: redesign the flow of partitioned topic auto-creation.
> >
> > I would like to recommend solution 2, and hope to hear more voices.
> >
> > Thanks
> > Yubiao Feng
> >
>

Reply via email to