Hi,<br><br>I I am a new user of logback and would like to use it in my project. Currently we are using log4j, but we have very strict performance requirements and it would be gr8 if logback performs better then log4j. I did some preliminary tests to compare the performace of the two ..and i observed that at some places logback is certainly better , but i also observed a behaviour which is contrary to what is described in the documentation. I am attaching the source code and my config files for the test . The queries I have are as following -
<br><br>1. The documentation says that the &quot;logbacklogger.debug(&quot;SEE IF THIS IS LOGGED {}.&quot;, i);&quot;&nbsp; is faster then <br><br>if (logbacklogger.isDebugEnabled())<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; logbacklogger.debug(&quot;SEE IF THIS IS LOGGED &quot; + i + &quot;.&quot;);
<br><br>but i observed that this is only true if the logging is configured for debug . For any other logging level the second approach is still more performant. This means that in a production env I must still have the check for isDebugEnabled. Is that intended or am i missing something.
<br><br>2. Something very strange that i observed in my test was that if i run my outer loop 10 times then always at the 7th invocation the logback took much longer time. I was able to get this behaviour consistently.<br>
<br><br>Anyways for the time being I am attaching my source code and the config files below ...maybe somebody can point out the errors or way of improvement.<br><br><br>########################################JAVA FILE##################################################
<br>package mandy.test.programs;<br><br>import org.slf4j.Logger;<br>import org.slf4j.LoggerFactory;<br><br>public class Logtester {<br><br>&nbsp; static Logger logbacklogger = LoggerFactory.getLogger(Logtester.class);<br>&nbsp; static 
org.apache.log4j.Logger log4jlogger = org.apache.log4j.Logger.getLogger(Logtester.class);<br><br>&nbsp; public static void main(String[] args) throws InterruptedException {<br><br>&nbsp;&nbsp;&nbsp; for (int j = 0; j &lt; 5; j++ ) {<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 
System.out.println(&quot;#######################################&quot;);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;TEST NUMBER &quot;+j);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;#######################################&quot;);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; long start = 
System.nanoTime();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for (int i = 0; i &lt; 500; i++ ) {<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; log4jlogger.debug(&quot;SEE IF THIS IS LOGGED &quot; + i + &quot;.&quot;);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;time taken in nanoseconds in first log4j test is &quot; + (
System.nanoTime() - start));<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; start = System.nanoTime();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for (int i = 0; i &lt; 500; i++ ) {<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if (log4jlogger.isDebugEnabled())<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; log4jlogger.debug(&quot;SEE IF THIS IS LOGGED &quot; + i + &quot;.&quot;);
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;time taken in nanoseconds in second log4j test is &quot; + (System.nanoTime() - start));<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Thread.sleep(1000);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; start = System.nanoTime();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for (int i = 0; i &lt; 500; i++ ) {
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; logbacklogger.debug(&quot;SEE IF THIS IS LOGGED &quot; + i + &quot;.&quot;);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;time taken in nanoseconds in first logback test is &quot; + (System.nanoTime() - start));
<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; start = System.nanoTime();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for (int i = 0; i &lt; 500; i++ ) {<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if (logbacklogger.isDebugEnabled())<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; logbacklogger.debug(&quot;SEE IF THIS IS LOGGED &quot; + i + &quot;.&quot;);
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;time taken in nanoseconds in second logback test is &quot; + (System.nanoTime() - start));<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Thread.sleep(1000);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; start = System.nanoTime();<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for (int i = 0; i &lt; 500; i++ ) {
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; logbacklogger.debug(&quot;SEE IF THIS IS LOGGED {}.&quot;, i);<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; System.out.println(&quot;time taken in nanoseconds in third logback test is &quot; + (System.nanoTime() - start));<br>&nbsp;&nbsp;&nbsp; }<br>
&nbsp; }<br>}<br><br><br><br><br>###################################################LOG4J CONFIG######################################<br>&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt; <br>&lt;!DOCTYPE log4j:configuration SYSTEM &quot;../resource/log4j.dtd&quot;&gt;
<br><br><br>&lt;log4j:configuration xmlns:log4j=&quot;<a href="http://jakarta.apache.org/log4j/">http://jakarta.apache.org/log4j/</a>&quot;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; debug=&quot;false&quot;&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;appender name=&quot;TestLogfile&quot; class=&quot;
org.apache.log4j.RollingFileAppender&quot;&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;param name=&quot;File&quot; value=&quot;d:/mandy/Test_Programs/testlog4j.log&quot;/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;param name=&quot;MaxFileSize&quot; value=&quot;1000KB&quot;/&gt;
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;param name=&quot;maxBackupIndex&quot; value=&quot;1&quot;/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;param name=&quot;Append&quot; value=&quot;true&quot;/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;layout class=&quot;org.apache.log4j.PatternLayout
&quot;&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;param name=&quot;ConversionPattern&quot; <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; value=&quot;%d{ISO8601} %5p [%t] %c{1} %X{transactionId} - %m%n&quot;/&gt;
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/layout&gt;<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/appender&gt;<br><br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;logger name=&quot;mandy.test.programs&quot; additivity=&quot;false&quot;&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;level value=&quot;debug&quot;/&gt;
<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;appender-ref ref=&quot;TestLogfile&quot;/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/logger&gt;<br><br><br>&lt;/log4j:configuration&gt;<br><br>#############################################LOGBACK CONFIG############################################
<br>&lt;configuration&gt;<br><br>&nbsp;&nbsp;&nbsp; &lt;appender name=&quot;TestLogfile&quot; class=&quot;ch.qos.logback.core.FileAppender&quot;&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;File&gt;d:/mandy/Test_Programs/testlogback.log&lt;/File&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;Append&gt;false&lt;/Append&gt;
<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;Encoding&gt;UTF-8&lt;/Encoding&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;BufferedIO&gt;true&lt;/BufferedIO&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;ImmediateFlush&gt;true&lt;/ImmediateFlush&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; <br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;layout class=&quot;ch.qos.logback.classic.PatternLayout
&quot;&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;Pattern&gt;%-4relative [%thread] %-5level %logger{35} - %msg%n&lt;/Pattern&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;/layout&gt;<br>&nbsp;&nbsp;&nbsp; &lt;/appender&gt;<br>&nbsp;&nbsp;&nbsp; <br>&nbsp;&nbsp;&nbsp; &lt;root&gt;<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;level value=&quot;debug&quot; /&gt;
<br>&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;appender-ref ref=&quot;TestLogfile&quot; /&gt;<br>&nbsp;&nbsp;&nbsp; &lt;/root&gt;<br>&lt;/configuration&gt;<br><br><br>#########################################OUTPUT WITH LOG LEVEL SET TO INFO IN BOTH CONFIG FILES ############################
<br>#######################################<br>TEST NUMBER 0<br>#######################################<br>time taken in nanoseconds in first log4j test is 1287035<br>time taken in nanoseconds in second log4j test is 425473
<br>time taken in nanoseconds in first logback test is 1988521<br>time taken in nanoseconds in second logback test is 60622<br>time taken in nanoseconds in third logback test is 1378387<br>#######################################
<br>TEST NUMBER 1<br>#######################################<br>time taken in nanoseconds in first log4j test is 2332139<br>time taken in nanoseconds in second log4j test is 115378<br>time taken in nanoseconds in first logback test is 1550756
<br>time taken in nanoseconds in second logback test is 50565<br>time taken in nanoseconds in third logback test is 374069<br>#######################################<br>TEST NUMBER 2<br>#######################################
<br>time taken in nanoseconds in first log4j test is 2050540<br>time taken in nanoseconds in second log4j test is 670755<br>time taken in nanoseconds in first logback test is 846756<br>time taken in nanoseconds in second logback test is 415974
<br>time taken in nanoseconds in third logback test is 1142044<br>#######################################<br>TEST NUMBER 3<br>#######################################<br>time taken in nanoseconds in first log4j test is 321828
<br>time taken in nanoseconds in second log4j test is 43581<br>time taken in nanoseconds in first logback test is 358985<br>time taken in nanoseconds in second logback test is 51962<br>time taken in nanoseconds in third logback test is 127390
<br>#######################################<br>TEST NUMBER 4<br>#######################################<br>time taken in nanoseconds in first log4j test is 323784<br>time taken in nanoseconds in second log4j test is 43581
<br>time taken in nanoseconds in first logback test is 362337<br>time taken in nanoseconds in second logback test is 45816<br>time taken in nanoseconds in third logback test is 124597<br>#######################################
<br>TEST NUMBER 5<br>#######################################<br>time taken in nanoseconds in first log4j test is 326578<br>time taken in nanoseconds in second log4j test is 43581<br>time taken in nanoseconds in first logback test is 5767493
<br>time taken in nanoseconds in second logback test is 25981<br>time taken in nanoseconds in third logback test is 103365<br>#######################################<br>TEST NUMBER 6<br>#######################################
<br>time taken in nanoseconds in first log4j test is 261206<br>time taken in nanoseconds in second log4j test is 28775<br>time taken in nanoseconds in first logback test is 239416<br>time taken in nanoseconds in second logback test is 5867
<br>time taken in nanoseconds in third logback test is 59505<br>#######################################<br>TEST NUMBER 7<br>#######################################<br>time taken in nanoseconds in first log4j test is 223492
<br>time taken in nanoseconds in second log4j test is 12851<br>time taken in nanoseconds in first logback test is 235784<br>time taken in nanoseconds in second logback test is 5867<br>time taken in nanoseconds in third logback test is 58667
<br>#######################################<br>TEST NUMBER 8<br>#######################################<br>time taken in nanoseconds in first log4j test is 220977<br>time taken in nanoseconds in second log4j test is 12851
<br>time taken in nanoseconds in first logback test is 238299<br>time taken in nanoseconds in second logback test is 5867<br>time taken in nanoseconds in third logback test is 61460<br>#######################################
<br>TEST NUMBER 9<br>#######################################<br>time taken in nanoseconds in first log4j test is 223212<br>time taken in nanoseconds in second log4j test is 12851<br>time taken in nanoseconds in first logback test is 237461
<br>time taken in nanoseconds in second logback test is 5308<br>time taken in nanoseconds in third logback test is 62019<br><br><br><br>#########################################OUTPUT WITH LOG LEVEL SET TO DEBUG IN BOTH CONFIG FILES ############################
<br>#######################################<br>TEST NUMBER 0<br>#######################################<br>time taken in nanoseconds in first log4j test is 85486004<br>time taken in nanoseconds in second log4j test is 35743649
<br>time taken in nanoseconds in first logback test is 22309540<br>time taken in nanoseconds in second logback test is 7795963<br>time taken in nanoseconds in third logback test is 19922365<br>#######################################
<br>TEST NUMBER 1<br>#######################################<br>time taken in nanoseconds in first log4j test is 39167827<br>time taken in nanoseconds in second log4j test is 33095826<br>time taken in nanoseconds in first logback test is 3618616
<br>time taken in nanoseconds in second logback test is 2657601<br>time taken in nanoseconds in third logback test is 6253309<br>#######################################<br>TEST NUMBER 2<br>#######################################
<br>time taken in nanoseconds in first log4j test is 12328941<br>time taken in nanoseconds in second log4j test is 13580218<br>time taken in nanoseconds in first logback test is 2401422<br>time taken in nanoseconds in second logback test is 2868521
<br>time taken in nanoseconds in third logback test is 4724902<br>#######################################<br>TEST NUMBER 3<br>#######################################<br>time taken in nanoseconds in first log4j test is 12460243
<br>time taken in nanoseconds in second log4j test is 11747583<br>time taken in nanoseconds in first logback test is 2559543<br>time taken in nanoseconds in second logback test is 2694477<br>time taken in nanoseconds in third logback test is 4801727
<br>#######################################<br>TEST NUMBER 4<br>#######################################<br>time taken in nanoseconds in first log4j test is 11915481<br>time taken in nanoseconds in second log4j test is 12330618
<br>time taken in nanoseconds in first logback test is 2379073<br>time taken in nanoseconds in second logback test is 2888076<br>time taken in nanoseconds in third logback test is 2698667<br>#######################################
<br>TEST NUMBER 5<br>#######################################<br>time taken in nanoseconds in first log4j test is 15098288<br>time taken in nanoseconds in second log4j test is 11025144<br>time taken in nanoseconds in first logback test is 8196013
<br>time taken in nanoseconds in second logback test is 2065067<br>time taken in nanoseconds in third logback test is 2888076<br>#######################################<br>TEST NUMBER 6<br>#######################################
<br>time taken in nanoseconds in first log4j test is 10594922<br>time taken in nanoseconds in second log4j test is 9976687<br>time taken in nanoseconds in first logback test is 2229892<br>time taken in nanoseconds in second logback test is 2172902
<br>time taken in nanoseconds in third logback test is 2692800<br>#######################################<br>TEST NUMBER 7<br>#######################################<br>time taken in nanoseconds in first log4j test is 10521728
<br>time taken in nanoseconds in second log4j test is 10123354<br>time taken in nanoseconds in first logback test is 2148597<br>time taken in nanoseconds in second logback test is 2135746<br>time taken in nanoseconds in third logback test is 2933893
<br>#######################################<br>TEST NUMBER 8<br>#######################################<br>time taken in nanoseconds in first log4j test is 10182579<br>time taken in nanoseconds in second log4j test is 10013563
<br>time taken in nanoseconds in first logback test is 2300851<br>time taken in nanoseconds in second logback test is 2087137<br>time taken in nanoseconds in third logback test is 2761803<br>#######################################
<br>TEST NUMBER 9<br>#######################################<br>time taken in nanoseconds in first log4j test is 9720230<br>time taken in nanoseconds in second log4j test is 10646605<br>time taken in nanoseconds in first logback test is 2647264
<br>time taken in nanoseconds in second logback test is 2164800<br>time taken in nanoseconds in third logback test is 2681905<br><br>