Hi,

Thanks for the suggestion! I’ve updated the KIP to use the worker config as
a command-line parameter. Please review the new version:
https://cwiki.apache.org/confluence/display/KAFKA/KIP-1209%3A+Add+configuration+to+control+internal+topic+creation+in+Kafka+Connect#KIP1209:AddconfigurationtocontrolinternaltopiccreationinKafkaConnect-InternalTopicsManagementScript

On Fri, Sep 19, 2025 at 12:59 AM Chris Egerton <fearthecel...@gmail.com>
wrote:

> Hi Anton,
>
> I think the tool as-is is mostly redundant since we already have the
> kafka-topics CLI. Maybe instead of accepting command-line parameters it can
> just take in a properties file that recognizes the exact same syntax we use
> in the worker config?
>
> Cheers,
>
> Chris
>
> On Thu, Sep 18, 2025, 05:10 Anton Liauchuk <anton93...@gmail.com> wrote:
>
> > Hi,
> >
> > I’ve added the CLI description to the proposal based on our discussion:
> >
> >
> https://cwiki.apache.org/confluence/display/KAFKA/KIP-1209%3A+Add+configuration+to+control+internal+topic+creation+in+Kafka+Connect#KIP1209:AddconfigurationtocontrolinternaltopiccreationinKafkaConnect-InternalTopicsManagementScript
> >
> > On Mon, Sep 15, 2025 at 12:17 PM Anton Liauchuk <anton93...@gmail.com>
> > wrote:
> >
> > > Thanks for the feedback!
> > >
> > >> Just to make sure we're all on the same page about the problem space
> > >> here--it seems like the only serious impact here could come from the
> > >> offsets topic. Creating a new, empty config or status topic should not
> > lead
> > >> to any problems if the existing one is accidentally deleted. Is this
> > >> correct?
> > >
> > > Yes, that’s correct - the offsets topic is the most critical case.
> > >
> > > An alternative flow could involve introducing a new CLI tool for
> creating
> > >> Connect's internal topics, with the intention that it could be used
> > before
> > >> bringing up any workers in the cluster, and then all workers in the
> > cluster
> > >> could be configured with internal topic creation disabled from day 1.
> We
> > >> could also recommend the use of that tool in the error message if
> > internal
> > >> topic creation is disabled and a topic isn't found.
> > >
> > > I agree - it makes total sense to have such a tool, which could be
> > > especially useful before creating a new Kafka Connect cluster. Should I
> > > update the KIP to include this proposed command-line tool?
> > >
> > > On Fri, Sep 12, 2025 at 10:21 PM Chris Egerton <ceger...@apache.org>
> > > wrote:
> > >
> > >> Hi Anton,
> > >>
> > >> I agree that, while rare, the case you've mentioned where a missing
> > >> offsets topic leads to reprocessing of potentially massive amounts of
> > data
> > >> is pretty nasty and it'd be nice to try to prevent it.
> > >>
> > >> Just to make sure we're all on the same page about the problem space
> > >> here--it seems like the only serious impact here could come from the
> > >> offsets topic. Creating a new, empty config or status topic should not
> > lead
> > >> to any problems if the existing one is accidentally deleted. Is this
> > >> correct?
> > >>
> > >> Separately, it seems like the intended flow is a bit awkward: users
> > bring
> > >> up a worker which automatically creates the internal topics, probably
> > bring
> > >> up more workers to flesh out the cluster, then have to edit the
> configs
> > for
> > >> every worker in the cluster in order to disable internal topic
> creation.
> > >> This would be okay in the case of a cluster migration, but it'd be
> > somewhat
> > >> cumbersome in the general case where a cluster has been brought up
> and,
> > >> with no plans of migration, users want to prevent accidental deletion
> of
> > >> the offsets topic from causing a ton of data to be reprocessed.
> > >>
> > >> An alternative flow could involve introducing a new CLI tool for
> > creating
> > >> Connect's internal topics, with the intention that it could be used
> > before
> > >> bringing up any workers in the cluster, and then all workers in the
> > cluster
> > >> could be configured with internal topic creation disabled from day 1.
> We
> > >> could also recommend the use of that tool in the error message if
> > internal
> > >> topic creation is disabled and a topic isn't found.
> > >>
> > >> Thoughts?
> > >>
> > >> On 2025/09/12 17:11:12 Anton Liauchuk wrote:
> > >> > Hi,
> > >> >
> > >> > Thanks for the feedback!
> > >> >
> > >> > I agree this should be a rare case, but the potential impact could
> be
> > >> > catastrophic in situations where many long-running connectors are
> > >> involved,
> > >> > as they might start reprocessing everything due to misconfiguration.
> > >> Such
> > >> > misconfiguration can happen because of invalid topic names or
> mistakes
> > >> > during migration to a new cluster. A recent example of this is the
> > >> > migration to a new Kafka cluster on AWS, the MSK cluster must be
> > >> recreated
> > >> > to migrate from ZooKeeper to KRaft.
> > >> >
> > >> > I’ve updated the KIP and PR:
> > >> >
> > >> >
> > >> >    -
> > >> >
> > >> >    Renamed the config to *internal.topics.creation.enable*
> > >> >    -
> > >> >
> > >> >    Extended the error messages. Example:
> > >> >
> > >> >    *Topic 'non-existent-offset' specified via the
> > 'offset.storage.topic'
> > >> >    property is missing. The config 'internal.topics.creation.enable'
> > is
> > >> set to
> > >> >    'false', so automatic creation of internal topics is disabled.
> > Either
> > >> >    enable automatic creation or create the topics manually before
> > >> starting the
> > >> >    worker.*
> > >> >
> > >> > Please take another look and share your thoughts
> > >> >
> > >> > On Fri, Sep 12, 2025 at 6:33 PM Mickael Maison <
> > >> mickael.mai...@gmail.com>
> > >> > wrote:
> > >> >
> > >> > > Hi,
> > >> > >
> > >> > > Thanks for the KIP.
> > >> > >
> > >> > > To be honest I'm unsure about this feature. I find the motivation
> > >> > > light, this targets a very specific error scenario.
> > >> > > If we set the new configuration to false, you then must manually
> > >> > > create the topics before the first start. Also all the internal
> > topic
> > >> > > configurations (offset.storage.partitions, etc) become unused.
> > >> > >
> > >> > > Then regarding the proposed configuration, have you considered
> > >> > > internal.topics.creation.enable?
> > >> > > Will the error message also specify the require configurations for
> > the
> > >> > > missing topics?
> > >> > >
> > >> > > Thanks,
> > >> > > Mickael
> > >> > >
> > >> > > On Wed, Sep 10, 2025 at 10:38 AM Andrei Rudkouski
> > >> > > <andrei.rudkou...@gmail.com> wrote:
> > >> > > >
> > >> > > > Hi,
> > >> > > >
> > >> > > > +1 (non-binding)
> > >> > > >
> > >> > > >  Thanks for the KIP
> > >> > > >
> > >> > > > Best regards,
> > >> > > > Andrei Rudkouski
> > >> > > >
> > >> > > > On 2025/09/09 09:07:14 Anton Liauchuk wrote:
> > >> > > > > hi
> > >> > > > >
> > >> > > > > I’ve added an integration test for this new config:
> > >> > > > >
> > >> > >
> > >>
> >
> https://github.com/apache/kafka/pull/20384/files#diff-0f86ed224068b85289d9214ae1dad88865d159b8e3658a4231544de36f429bd5R248
> > >> > > > > .
> > >> > > > >
> > >> > > > >
> > >> > > > > Please take a look at the KIP - it’s a really small
> > configuration.
> > >> > > > >
> > >> > > > > Once we get the required number of votes, the PR can be
> merged.
> > >> > > > >
> > >> > > > > On Thu, Sep 4, 2025 at 9:49 PM Hector Geraldino (BLOOMBERG/
> 919
> > >> 3RD A)
> > >> > > <
> > >> > > > > hgerald...@bloomberg.net> wrote:
> > >> > > > >
> > >> > > > > > +1 (non-binding)
> > >> > > > > >
> > >> > > > > > Thanks for the KIP
> > >> > > > > >
> > >> > > > > > From: dev@kafka.apache.org At: 09/04/25 13:24:06
> UTC-4:00To:
> > >> > > > > > dev@kafka.apache.org
> > >> > > > > > Subject: [VOTE] KIP-1209: Add configuration to control
> > internal
> > >> topic
> > >> > > > > > creation in Kafka Connect
> > >> > > > > >
> > >> > > > > > hi
> > >> > > > > >
> > >> > > > > > I would like to start a vote on *KIP-1209: Add configuration
> > to
> > >> > > control
> > >> > > > > > internal topic creation in Kafka Connect*
> > >> > > > > >
> > >> > > > > > KIP: https://cwiki.apache.org/confluence/x/GAq2Fg
> > >> > > > > > Discussion thread:
> > >> > > > > >
> > >> https://lists.apache.org/thread/l89rzzm0jd4ml7xx66mkxfztst281so7
> > >> > > > > >
> > >> > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > >
> > >> >
> > >>
> > >
> >
>

Reply via email to