I have a logback.xml file with 3 appender in : 1 ConsoleAppender and 2 FileAppender
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<Target>System.out</Target>
<encoder>
<pattern>[%d{yyyy-MM-dd HH:mm:ss}] %msg%m%n%ex</pattern>
</encoder>
</appender>
<appender name="bAppender" class="ch.qos.logback.core.FileAppender">
<file>logs/b.txt</file>
<append>true</append>
<encoder>
<pattern>[%d{yyyy-MM-dd HH:mm:ss}] -[%t] %-4r %-5p %c : %n%m%n</pattern>
</encoder>
</appender>
<appender name="aAppender" class="ch.qos.logback.core.FileAppender">
<file>logs/a.txt</file>
<append>false</append>
<encoder>
<pattern>[%d{dd/MM/yyyy : HH:mm:ss} %level - %logger] %m%n</pattern>
</encoder>
</appender>
<logger name="aLogger" additivity="false">
<level value="DEBUG" />
<appender-ref ref="aAppender" />
</logger>
<root level="info">
<appender-ref ref="stdout"/>
</root>
</configuration>
The problem is when i launch the program associated with aLogger(Logger LOGGER = LoggerFactory.getLogger("aLogger");
. It add the bAppend as well ( and so create a empty b.txt file ....)
It's like logback call and execute all appender when a logger is called regardless attached appender. How to avoid this behaviour ?
Thank you very much