Hi everyone

I have updated the content of KIP.
I want to highlight that although we set log4j2 as the default server-side
logging framework we couldn't change its scope to implementation in
`build.gradle`.
This will lead the downstream projects to encounter dependency conflicts.

Please take a look and share your feedback.

Best,
TengYao

TengYao Chi <kiting...@gmail.com> 於 2025年3月23日 週日 下午2:23寫道:

> Hi Stig
>
> Sorry for the late reply, and thanks for your question. 😀
>
> The title "Upgrade slf4j to 2.x" represents the core change enabling
> improved logging backend selection.
> The fundamental change is the SLF4J upgrade, which brings the new provider
> selection mechanism (`-Dslf4j.provider`) as a key feature.
> Given that, I think the current title reflects the primary technical
> change, while the KIP details explain the resulting benefits and
> implementation approach.
>
> Best,
> TengYao
>
>
> Stig Rohde Døssing <stigdoess...@gmail.com> 於 2025年3月21日 週五 下午11:46寫道:
>
>> The title of the KIP seems a little odd, because if I understand
>> correctly,
>> the main change you want to make is to bundle multiple logging backends
>> with Kafka and make them selectable via a system property, and upgrading
>> sfl4j is a means to achieve that, not the goal itself?
>>
>> Den fre. 21. mar. 2025 kl. 12.18 skrev Chia-Ping Tsai <chia7...@gmail.com
>> >:
>>
>> > hi Teng
>> >
>> > > The KIP will document that log4j2 is the only officially supported
>> >    server-side logging framework, and we will expose its configuration
>> file
>> > to
>> >    users.
>> >
>> > on the server-side, we should keep current scope - compileOnly and
>> > releaseOnly - Otherwise, downstream projects could encounter dependency
>> > conflicts [0]
>> >
>> > >  I will revise the motivation section of the KIP to emphasize that the
>> >
>> > Please include the following description.
>> >
>> > "The rationale for this KIP is that upgrading SLF4J necessitates
>> > corresponding provider upgrades, which constitutes a breaking change."
>> >
>> > Also, we must upgrade the Log4j2 dependency based on SLF4J 2 (i.e.,
>> > log4j-slf4j-impl to log4j-slf4j2-impl) in 5.0 if we upgrade to slf4j2
>> >
>> > [0] https://github.com/apache/kafka/pull/17373#issuecomment-2577813317
>> >
>> > Best,
>> >
>> > Chia-Ping
>> >
>> >
>> > TengYao Chi <kiting...@gmail.com> 於 2025年3月21日 週五 下午6:52寫道:
>> >
>> > > Hello everyone,
>> > >
>> > > Sorry for the late reply.
>> > > Based on the previous discussion, I would like to conclude with the
>> > > following points:
>> > >
>> > >    1. The upgrade to slf4j2 should be postponed to Kafka 5.0 due to
>> > >    compatibility issues.
>> > >    2. I will revise the motivation section of the KIP to emphasize
>> that
>> > the
>> > >    key benefit is allowing users to select logging backends through
>> > >    configuration rather than modifying JAR files.
>> > >    3. After the slf4j upgrade, users will be able to use the
>> > >    `-Dslf4j.provider` system property to configure their preferred
>> > logging
>> > >    backend.
>> > >    4. The KIP will document that log4j2 is the only officially
>> supported
>> > >    server-side logging framework, and we will expose its configuration
>> > > file to
>> > >    users.
>> > >    To avoid breaking downstream compatibility, we will not bind the
>> > client
>> > >    side to any specific logging framework. Users will need to manage
>> > their
>> > > own
>> > >    logging libraries, but they can utilize the `-Dslf4j.provider`
>> > property
>> > >    once slf4j is upgraded.
>> > >    5. We have rejected alternatives that involve warnings and
>> classpath
>> > >    ordering as they do not provide a solid solution to compatibility
>> > > issues.
>> > >
>> > > Does this summary make sense?
>> > >
>> > > Best,
>> > > TengYao
>> > >
>> > > Ismael Juma <m...@ismaeljuma.com> 於 2025年3月21日 週五 上午9:32寫道:
>> > >
>> > > > A solution that involves a warning and classpath ordering doesn't
>> meet
>> > > the
>> > > > bar for me. Good clarification though.
>> > > >
>> > > > Ismael
>> > > >
>> > > > On Thu, Mar 20, 2025 at 8:37 AM Farid Zakaria
>> > > > <fzaka...@confluent.io.invalid>
>> > > > wrote:
>> > > >
>> > > > > AFAIR SLF4J you don't have to remove the other backends; merely
>> make
>> > > > > sure yours is first on the CLASSPATH list :P
>> > > > > (SLF4J pre 2.0 would always emit a warning that it found 2+
>> > > > StaticBinders)
>> > > > >
>> > > > > Interestingly, you could still whatever backend (i.e. Log4J) and
>> pipe
>> > > > > it through to another backend via another appender.
>> > > > > This is what SLF4J refers to bridges -- although you have to be
>> sure
>> > > > > not to create a circular loop.
>> > > > >
>> > > > > Then there is something also general like syslog.
>> > > > >
>> > > > > On Thu, Mar 20, 2025 at 1:15 AM Chia-Ping Tsai <
>> chia7...@gmail.com>
>> > > > wrote:
>> > > > > >
>> > > > > > hi Ismael
>> > > > > >
>> > > > > > thanks for all your response.
>> > > > > >
>> > > > > > > All that said, I am not actually sure we can do what I
>> described
>> > > > above
>> > > > > > while maintaining the compatibility required by a minor release.
>> > > > > >
>> > > > > > Excuse me, are your concerns related to version matching, as
>> > > discussed
>> > > > in
>> > > > > > [0]? If so, I concur that this represents a compatibility issue,
>> > and
>> > > > the
>> > > > > > target version for this change should be 5.0. Additionally,
>> there
>> > > was a
>> > > > > > related discussion previously documented in [1]. While we have
>> not
>> > > > > strictly
>> > > > > > enforced version matching during prior SLF4J updates, this KIP
>> > > provides
>> > > > > an
>> > > > > > opportunity to establish guidelines for upgrading sl4fj that
>> have
>> > > > direct
>> > > > > > compatibility implications.
>> > > > > >
>> > > > > > [0] https://www.slf4j.org/faq.html#compatibility
>> > > > > > [1]
>> > > https://github.com/apache/kafka/pull/16324#discussion_r1644671854
>> > > > > >
>> > > > > > To Teng
>> > > > > >
>> > > > > > Could you please revise the KIP according to following benefit?
>> > > > > >
>> > > > > > > The key benefit of this KIP is that you can add new logging
>> > > backends
>> > > > > and
>> > > > > > select it via a config. This is how most pluggable things work.
>> But
>> > > it
>> > > > is
>> > > > > > *not* how slf4j 1.x works. slf4j 1.x requires you to *remove*
>> the
>> > > > default
>> > > > > > logging library picked by the project as well. That's much more
>> > > > > intrusive.
>> > > > > >
>> > > > > > Best,
>> > > > > > Chia-Ping
>> > > > > >
>> > > > > > Ismael Juma <m...@ismaeljuma.com> 於 2025年3月20日 週四 上午8:10寫道:
>> > > > > >
>> > > > > > > Hi Chia-Ping,
>> > > > > > >
>> > > > > > > I don't think we're in the business of shipping multiple
>> logging
>> > > > > libraries.
>> > > > > > > Here's my take:
>> > > > > > >
>> > > > > > > 1. We should pick one logging library for services/servers,
>> ship
>> > it
>> > > > and
>> > > > > > > include a configuration file for it.
>> > > > > > > 2. For clients, we leave it to the users to select the logging
>> > > > library
>> > > > > -
>> > > > > > > clients run alongside applications and it's desirable to use
>> the
>> > > same
>> > > > > > > logging library for both (if we were starting from scratch, we
>> > may
>> > > > have
>> > > > > > > decided to also include our default logging library for
>> clients
>> > as
>> > > > > well,
>> > > > > > > but it's hard to make that change now).
>> > > > > > > 3. For the cases where users want to use a different logging
>> > > library
>> > > > > for
>> > > > > > > services/servers (perhaps because they have standardized on a
>> > > > different
>> > > > > > > logging library), they would have to add the additional jar to
>> > the
>> > > > > > > classpath and change the relevant logging config. This is no
>> > > > different
>> > > > > than
>> > > > > > > adding a different authorizer or any other pluggable
>> component.
>> > > > > > >
>> > > > > > > The key benefit of this KIP is that you can add new logging
>> > > backends
>> > > > > and
>> > > > > > > select it via a config. This is how most pluggable things
>> work.
>> > But
>> > > > it
>> > > > > is
>> > > > > > > *not* how slf4j 1.x works. slf4j 1.x requires you to *remove*
>> the
>> > > > > default
>> > > > > > > logging library picked by the project as well. That's much
>> more
>> > > > > intrusive.
>> > > > > > >
>> > > > > > > All that said, I am not actually sure we can do what I
>> described
>> > > > above
>> > > > > > > while maintaining the compatibility required by a minor
>> release.
>> > > > > > >
>> > > > > > > Ismael
>> > > > > > >
>> > > > > > > On Wed, Mar 19, 2025, 2:03 PM Chia-Ping Tsai <
>> chia7...@gmail.com
>> > >
>> > > > > wrote:
>> > > > > > >
>> > > > > > > > hi Ismael
>> > > > > > > >
>> > > > > > > > > but they must also add whichever logging library they
>> want to
>> > > > use.
>> > > > > > > >
>> > > > > > > > If users are required to modify JAR files to alter the SLF4J
>> > > > > provider,
>> > > > > > > the
>> > > > > > > > value of this KIP is significantly diminished. I believe the
>> > > > primary
>> > > > > > > > benefit of this KIP lies in enabling users to configure a
>> > system
>> > > > > property
>> > > > > > > > for SLF4J provider changes without JAR modifications.
>> > > Furthermore,
>> > > > by
>> > > > > > > > managing all SLF4J and provider JARs within Kafka, we can
>> > ensure
>> > > > > SLF4J
>> > > > > > > > version updates without compatibility concerns, as we can
>> > > guarantee
>> > > > > > > > provider JAR consistency with the SLF4J version in the
>> > > > distribution.
>> > > > > > > >
>> > > > > > > > Best,
>> > > > > > > > Chia-Ping
>> > > > > > > >
>> > > > > > > > Ismael Juma <m...@ismaeljuma.com> 於 2025年3月19日 週三 下午12:00寫道:
>> > > > > > > >
>> > > > > > > > > Hi TengYao,
>> > > > > > > > >
>> > > > > > > > > It's a bit difficult to review the KIP. I don't follow
>> most
>> > of
>> > > > the
>> > > > > > > > > motivation. The only one that I follow is:
>> > > > > > > > >
>> > > > > > > > > "Our current build configuration employs fragile
>> dependency
>> > > > > management
>> > > > > > > > > tricks to handle SLF4J backends. We can eliminate these
>> > brittle
>> > > > > build
>> > > > > > > > > mechanisms by transitioning to explicit provider
>> dependencies
>> > > > after
>> > > > > > > > > upgrading to 2.0."
>> > > > > > > > >
>> > > > > > > > > Additionally, I don't think we should do the following:
>> > > > > > > > >
>> > > > > > > > > "Add other popular slf4j backend binding provider
>> > > dependencies."
>> > > > > > > > >
>> > > > > > > > > A reasonable approach, in my opinion, would be:
>> > > > > > > > >
>> > > > > > > > > 1. Include the log4j2 dependency with the server modules
>> and
>> > > not
>> > > > > > > include
>> > > > > > > > > them with the client modules.
>> > > > > > > > > 2. Automatically configure the log4j2 dependency for the
>> > server
>> > > > > > > modules.
>> > > > > > > > > Users can override them via the system property, but they
>> > must
>> > > > > also add
>> > > > > > > > > whichever logging library they want to use.
>> > > > > > > > > 3. Somehow configure slf4j 2.x to work like 1.x out of the
>> > box
>> > > > for
>> > > > > the
>> > > > > > > > > client module (for compatibility reasons).
>> > > > > > > > >
>> > > > > > > > > But I don't know if `3` is possible. If `3` is not
>> possible,
>> > I
>> > > > > don't
>> > > > > > > see
>> > > > > > > > > how we can make this a compatible change.
>> > > > > > > > >
>> > > > > > > > > Ismael
>> > > > > > > > >
>> > > > > > > > > On Tue, Mar 18, 2025 at 7:41 PM TengYao Chi <
>> > > kiting...@gmail.com
>> > > > >
>> > > > > > > wrote:
>> > > > > > > > >
>> > > > > > > > > > Hello everyone,
>> > > > > > > > > >
>> > > > > > > > > > I want to bump this thread manually.
>> > > > > > > > > > Any feedback or vote would be appreciated.
>> > > > > > > > > >
>> > > > > > > > > > Best,
>> > > > > > > > > > TengYao
>> > > > > > > > > >
>> > > > > > > > > > TengYao Chi <kiting...@gmail.com> 於 2025年3月10日 週一
>> > 上午11:47寫道:
>> > > > > > > > > >
>> > > > > > > > > > > Hello guys,
>> > > > > > > > > > > I would like to remind you in the vote thread that the
>> > KIP
>> > > > has
>> > > > > been
>> > > > > > > > > > > updated, and I apologize for repeating it.
>> > > > > > > > > > > I have taken over this KIP from Muralidhar.
>> > > > > > > > > > > Since the original content is outdated as the logging
>> > > > > framework has
>> > > > > > > > > been
>> > > > > > > > > > > widely changed, I have updated the content of the KIP.
>> > > > > > > > > > > Please take a look and share your thoughts.
>> > > > > > > > > > >
>> > > > > > > > > > > Best Regards,
>> > > > > > > > > > > TengYao
>> > > > > > > > > > >
>> > > > > > > > > > > Muralidhar Basani <muralidhar.bas...@aiven.io.invalid>
>> 於
>> > > > > > > 2024年9月24日
>> > > > > > > > 週二
>> > > > > > > > > > > 上午5:09寫道:
>> > > > > > > > > > >
>> > > > > > > > > > >> Hi,
>> > > > > > > > > > >>
>> > > > > > > > > > >> I wanted to gently follow up on this thread in case
>> > anyone
>> > > > > has any
>> > > > > > > > > > >> thoughts
>> > > > > > > > > > >> or would like to take a look.
>> > > > > > > > > > >>
>> > > > > > > > > > >> Thanks,
>> > > > > > > > > > >> Murali
>> > > > > > > > > > >>
>> > > > > > > > > > >> On Mon, Sep 16, 2024 at 10:23 AM Muralidhar Basani <
>> > > > > > > > > > >> muralidhar.bas...@aiven.io> wrote:
>> > > > > > > > > > >>
>> > > > > > > > > > >> > Thanks Chia.
>> > > > > > > > > > >> >
>> > > > > > > > > > >> > I have updated KIP with this quote, in the
>> migration
>> > > plan
>> > > > > > > section.
>> > > > > > > > > > >> >
>> > > > > > > > > > >> > Thanks,
>> > > > > > > > > > >> > Murali
>> > > > > > > > > > >> >
>> > > > > > > > > > >> > On Sun, Sep 15, 2024 at 3:30 PM Chia-Ping Tsai <
>> > > > > > > > chia7...@gmail.com>
>> > > > > > > > > > >> wrote:
>> > > > > > > > > > >> >
>> > > > > > > > > > >> >>
>> > > > > > > > > > >> >> > Muralidhar Basani <muralidhar.bas...@aiven.io
>> > > .invalid>
>> > > > 於
>> > > > > > > > > > 2024年9月15日
>> > > > > > > > > > >> >> 晚上9:02 寫道:
>> > > > > > > > > > >> >> >
>> > > > > > > > > > >> >> > With this, I think, users don't have to make any
>> > > > explicit
>> > > > > > > > changes
>> > > > > > > > > > in
>> > > > > > > > > > >> >> their
>> > > > > > > > > > >> >> > code, if their provider is reload4j. And if
>> it's a
>> > > > > different
>> > > > > > > > > > provider
>> > > > > > > > > > >> >> (like
>> > > > > > > > > > >> >> > logback, log4j), they would have to upgrade
>> that to
>> > > > > match it
>> > > > > > > > with
>> > > > > > > > > > >> slf4j.
>> > > > > > > > > > >> >>
>> > > > > > > > > > >> >> If upgrading the matched provider is the only
>> > explicit
>> > > > > change
>> > > > > > > and
>> > > > > > > > > we
>> > > > > > > > > > >> >> expect users have responsibility to keep
>> consistent
>> > > > version
>> > > > > > > when
>> > > > > > > > > > using
>> > > > > > > > > > >> >> other providers , could we write it down to the
>> KIP?
>> > > > > > > > > > >> >>
>> > > > > > > > > > >> >> That means we will update slf4j without KIP in the
>> > > future
>> > > > > > > except
>> > > > > > > > > for
>> > > > > > > > > > >> >> specific reason.
>> > > > > > > > > > >> >>
>> > > > > > > > > > >> >> Best,
>> > > > > > > > > > >> >> Chia-Ping
>> > > > > > > > > > >> >
>> > > > > > > > > > >> >
>> > > > > > > > > > >>
>> > > > > > > > > > >
>> > > > > > > > > >
>> > > > > > > > >
>> > > > > > > >
>> > > > > > >
>> > > > >
>> > > >
>> > >
>> >
>>
>

Reply via email to