René Link created LOG4J2-2914:
---------------------------------

             Summary: Kafka Producer Thread not shutdown when logging is 
reinitialized
                 Key: LOG4J2-2914
                 URL: https://issues.apache.org/jira/browse/LOG4J2-2914
             Project: Log4j 2
          Issue Type: Bug
          Components: Appenders
    Affects Versions: 2.13.3
            Reporter: René Link
         Attachments: maven-project-to-reproduce.zip

I define a KafkaAppender, e.g. Named "Kafka", in the configuration and on 
startup of my application the logging configuration is initialized. Thus a 
Kafka producer thread exists.

When I now reconfigure the logging programmatically later and the new 
configuration also contains a KafkaAppender named "Kafka" the old Kafka 
producer is not shut down.

After the new configuration is initialized two Kafka producer threads exist, 
but only 1 KafkaAppender was defined in the new configuration. Thus the old one 
has not been shut down.

 

 

I have attached a zipped maven project to reproduce the problem.

When you execute the Main class

{{Logger logger = LogManager.getLogger(Main.class); }}
{{// logging initialized}}
{{ printKafkaThreads();}}
{{ // reinitialize }}
{{Configurator.initialize(null, Main.class.getClassLoader(), 
"log4j2-reinitialized.xml");}}
{{ printKafkaThreads();}}

{{you will see the output}}

{{======================}}
{{Thread[kafka-producer-network-thread | producer-1,5,main]}}
{{======================}}
{{======================}}
{{Thread[kafka-producer-network-thread | producer-2,5,main]}}
{{Thread[kafka-producer-network-thread | producer-1,5,main]}}
{{======================}}

{{I guess the problem is that the KafkaAppender starts the KafkaManager and the 
KafkaManger does not check if the producer is already started. So it overrides 
it and therefore forgets the reference and thus can not shutdown the lose 
producer anymore.}}

 



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to