Skip to content

Remove warning logs of unknown configs for Kafka passwordless

yiliu6 edited this page Nov 14, 2022 · 11 revisions
  • Problem statement
  • User scenarios
  • Goal
  • Exit criteria

Problem statement

As is reported in https://github.com/Azure/azure-sdk-for-java/issues/30800#issuecomment-1254620865, when using Event Hubs for Kafka passwordless-conneciton, there are a batch of warning logs saying, "The configuration 'xxx' was supplied but isn't a known config". We should consider preventing those warning logs being printed.

User scenarios

Currently there are 3 scenarios that developer uses Kafka password-less connection from the perspective of configuration, and all of them can bring in the warning logs:

  1. By default, developers use the least and required properties:
    # When using org.springframework.cloud:spring-cloud-starter-stream-kafka, developers set the only required broker config
    spring.cloud.stream.kafka.binder.brokers=<namespace>.servicebus.windows.net:9093
    or
    # When using org.springframework.kafka:spring-kafka in a Spring Boot application, developers set the only required bootstrap-server config
    spring.kafka.bootstrap-servers=<namespace>.servicebus.windows.net:9093
  2. When developers manually configure any customized credential/profile properties via Spring Cloud Azure global configuration:
    # When using org.springframework.cloud:spring-cloud-starter-stream-kafka
    spring.cloud.stream.kafka.binder.brokers=<namespace>.servicebus.windows.net:9093
    spring.cloud.azure.credential.managed-identity-enabled=true
    or
    # When using org.springframework.kafka:spring-kafka in a Spring Boot application
    spring.kafka.bootstrap-servers=<namespace>.servicebus.windows.net:9093
    spring.cloud.azure.credential.managed-identity-enabled=true
  3. When developers manually configure any customized credential/profile properties via Kafka configuration:
    # When using org.springframework.cloud:spring-cloud-starter-stream-kafka
    spring.cloud.stream.kafka.binder.brokers=<namespace>.servicebus.windows.net:9093
    spring.cloud.stream.kafka.binder.producer-properties.azure.credential.managed-identity-enabled=true
    or
    # When using org.springframework.kafka:spring-kafka in a Spring Boot application
    spring.kafka.bootstrap-servers=<namespace>.servicebus.windows.net:9093
    spring.kafka.properties.azure.credential.managed-identity-enabled=true

Goal

We should make sure there won't be any warning logs in the above 3 cases. That's to say, developers could keep the existing way of using Kafka password-less connection including the same API, properties for spring boot and cloud stream, library dependency. But will not see any warning logs of "The configuration 'xxx' was supplied but isn't a known config".

Exit criteria

  1. With all the above mentioned 3 scenarios, the application can connect successfully without warning logs of "The configuration 'xxx' was supplied but isn't a known config".
  2. We should make sure the existing functions won't be broken by this feature:
    1. We developers set customzied properties from Spring Cloud Azure properties, Spring Boot Kafka properties and SCS Kafka binder properties, then those configuration should still take effects to the Event Hubs connection.
    2. When developers set properties from Spring Boot Kafka properties, we should make sure it can be passed to SCS Kafka without warnings.
Clone this wiki locally