<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"><!-- P {margin-top:0;margin-bottom:0;} --></style>
</head>
<body dir="ltr">
<div id="divtagdefaultwrapper" style="font-size:12pt;color:#000000;background-color:#FFFFFF;font-family:Calibri,Arial,Helvetica,sans-serif;">
<p>Hi all,</p>
<p><br>
</p>
<p>We use Virgo server and it comes with Logback 1.0.7.v20121108-1250. One of the users of our product started complaining that after about a week of using our product, it was becoming so slow that it was basically unusable. We had a live session with the client
 and it turned out that the problem was in Logback. The client uses Windows. So far the problem has not been reported on Linux. Here's what I did to determine that Logback was the cause of the problem:<br>
</p>
<p><br>
</p>
<p>1. The appender is defined as:</p>
<p><br>
</p>
<p>   <appender name="LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"><br>
      <file>D:/logs/product.log</file><br>
      <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy"><br>
         <FileNamePattern>D:/logs/product_%i.log.zip</FileNamePattern><br>
         <MinIndex>0</MinIndex><br>
         <MaxIndex>9</MaxIndex><br>
      </rollingPolicy><br>
</p>
      <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"><br>
         <MaxFileSize>50MB</MaxFileSize><br>
      </triggeringPolicy><br>
      <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"><br>
         <Pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.SSSXXX}] [%-5level] %-28.28thread %X{sessionGuid} %-64.64logger{64} %X{medic.eventCode} %msg %ex%n</Pattern><br>
      </encoder><br>
   </appender><br>
<p><br>
</p>
<p>In the appender configuration above, I modified the directories and log names a little bit, so that the actual product name would not be visible.<br>
</p>
<p><br>
</p>
<p>2. All the rolled-over zip files were generated and present, and the main log file, product.log, had exceeded its maximum size of 50 MB and had reached 64 MB. We had something like:</p>
<p><br>
</p>
<p>product.log           <------- 64 MB</p>
<p>product_0.log.zip</p>
<p></p>
<p>product_1.log.zip</p>
<p>product_2.log.zip</p>
<p>product_3.log.zip</p>
<p>product_4.log.zip</p>
<p>product_5.log.zip</p>
<p>product_6.log.zip</p>
<p>product_7.log.zip</p>
<p>product_8.log.zip</p>
<p>product_9.log.zip</p>
<p></p>
<p><br>
</p>
<p>3. This was suspicious, so I examined the log file and saw many messages that were logged out of order, e.g.</p>
<p><br>
</p>
<p>09:55:43.676<br>
09:55:42.836<br>
09:55:46.165<br>
09:55:44.583<br>
...</p>
<p><br>
</p>
<p>Furthermore, even the simplest operations, e.g. simply sending a redirect response back to the browser, was taking several seconds. (However, before sending the redirect, we were logging the URL to which we were redirecting, so I suspected that the logger
 was extremely slow.)<br>
</p>
<p><br>
</p>
<p>3. I moved the archived log files to a different directory and they got recreated *immediately*. I did this 7-8 times, each time with exactly the same result -- the .zip files got recreated immediately.</p>
<p><br>
</p>
<p>4. The main log, product.log, was locked by the JVM, so I couldn't move it or delete it. However, I opened it with a text editor, selected the whole content (Ctrl+A), deleted it (Del) and saved the file. As soon as I did that, the performance problems disappeared.
 The product began working normally. Also, the log file started growing with normal speed. Previously, it was growing super-slowly.</p>
<p><br>
</p>
<p><br>
</p>
<p>So, we told the users to do the following workaround when the preconditions from step 2 above were reached and the product became very slow:</p>
<p><br>
</p>
<p>(1) Open the main log file, select all, delete, save.</p>
<p>(2) Delete all archived .zip files</p>
<p><br>
</p>
<p>This workaround has been working fine so far. However, we still don't know why Logback behaves like this. That's why I'm writing this email. Can someone, who knows the Logback source code, figure out what might be happening and what triggers it?</p>
<p><br>
</p>
<p>Here are some additional details that we've been able to figure out:</p>
<p><br>
</p>
<p>1. When the users were experiencing the problem during the live session with them, I opened ProcessExplorer and saw that Splunk was holding a lock onto the main log file -- product log. I asked the users to kill the Splunk service and they did, but that
 didn't solve the problem. However, depending on the way Logback is written, it may turn out that it indeed went crazy because of Splunk, but *after* it goes crazy, killing the other process that hold a lock on the file doesn't help.
</p>
<p><br>
</p>
<p>2. We managed to reproduce the same behavior in our company by letting two different appenders write to the same log file. Then, as soon as the preconditions on step 2 above were reached, everything became extremely slow, the logs couldn't roll over and
 the main log started growing beyond its specified limit of 50 MB. However, the users do *not* have such a configuration in which two appenders write to the same file. I'm only giving you information on how we managed to reproduce the slowness in case it might
 help you figure out what's wrong. The end result is the same -- Logback slows down to a crawl, but apparently the trigger in our users' environment is different and it's not related to appenders writing to the same file.</p>
<p><br>
</p>
<p>3. A thread dump while we were reproducing the problem (with two appenders writing to the same file) reveals the following:</p>
<p><br>
</p>
<p>3.1. One thread holds a lock (0x00000000dfa5d600):</p>
<p><br>
</p>
<p>"Thread-48" #199 daemon prio=5 os_prio=0 tid=0x0000000024b61000 nid=0x772c runnable [0x000000002422e000]<br>
   java.lang.Thread.State: RUNNABLE<br>
    at java.util.zip.Deflater.deflateBytes(Native Method)<br>
    at java.util.zip.Deflater.deflate(Deflater.java:442)<br>
    - locked <0x00000000fdb8dcf0> (a java.util.zip.ZStreamRef)<br>
    at java.util.zip.Deflater.deflate(Deflater.java:364)<br>
    at java.util.zip.DeflaterOutputStream.deflate(DeflaterOutputStream.java:251)<br>
    at java.util.zip.DeflaterOutputStream.write(DeflaterOutputStream.java:211)<br>
    at java.util.zip.ZipOutputStream.write(ZipOutputStream.java:331)<br>
    - locked <0x00000000fdb8da00> (a java.util.zip.ZipOutputStream)<br>
    at ch.qos.logback.core.rolling.helper.Compressor.zipCompress(Compressor.java:110)<br>
    at ch.qos.logback.core.rolling.helper.Compressor.compress(Compressor.java:58)<br>
    at ch.qos.logback.core.rolling.FixedWindowRollingPolicy.rollover(FixedWindowRollingPolicy.java:147)<br>
    at ch.qos.logback.core.rolling.RollingFileAppender.rollover(RollingFileAppender.java:111)<br>
    - locked <0x00000000dfa5d460> (a ch.qos.logback.core.spi.LogbackLock)<br>
    at ch.qos.logback.core.rolling.RollingFileAppender.subAppend(RollingFileAppender.java:144)<br>
    - locked <0x00000000dfa5d600> (a ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy)<br>
    at ch.qos.logback.core.OutputStreamAppender.append(OutputStreamAppender.java:103)<br>
    at ch.qos.logback.core.UnsynchronizedAppenderBase.doAppend(UnsynchronizedAppenderBase.java:88)<br>
    at ch.qos.logback.core.spi.AppenderAttachableImpl.appendLoopOnAppenders(AppenderAttachableImpl.java:48)<br>
    at ch.qos.logback.classic.Logger.appendLoopOnAppenders(Logger.java:280)<br>
    at ch.qos.logback.classic.Logger.callAppenders(Logger.java:267)<br>
    at ch.qos.logback.classic.Logger.buildLoggingEventAndAppend(Logger.java:449)<br>
    at ch.qos.logback.classic.Logger.filterAndLog_0_Or3Plus(Logger.java:403)<br>
    at ch.qos.logback.classic.Logger.log(Logger.java:803)<br>
    at org.apache.commons.logging.impl.SLF4JLocationAwareLog.warn(SLF4JLocationAwareLog.java:185)<br>
    ...<br>
<br>
</p>
<p>3.2. A multitude of threads are blocked and waiting to acquire that lock, e.g.:</p>
<p><br>
</p>
<p>"Thread-55" #206 daemon prio=5 os_prio=0 tid=0x000000001f50d000 nid=0x7288 waiting for monitor entry [0x00000000263ef000]<br>
   java.lang.Thread.State: BLOCKED (on object monitor)<br>
    at ch.qos.logback.core.rolling.RollingFileAppender.subAppend(RollingFileAppender.java:142)<br>
    - waiting to lock <0x00000000dfa5d600> (a ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy)<br>
    at ch.qos.logback.core.OutputStreamAppender.append(OutputStreamAppender.java:103)<br>
    at ch.qos.logback.core.UnsynchronizedAppenderBase.doAppend(UnsynchronizedAppenderBase.java:88)<br>
    at ch.qos.logback.core.spi.AppenderAttachableImpl.appendLoopOnAppenders(AppenderAttachableImpl.java:48)<br>
    at ch.qos.logback.classic.Logger.appendLoopOnAppenders(Logger.java:280)<br>
    at ch.qos.logback.classic.Logger.callAppenders(Logger.java:267)<br>
    at ch.qos.logback.classic.Logger.buildLoggingEventAndAppend(Logger.java:449)<br>
    at ch.qos.logback.classic.Logger.filterAndLog_0_Or3Plus(Logger.java:403)<br>
    at ch.qos.logback.classic.Logger.log(Logger.java:803)<br>
    at org.apache.commons.logging.impl.SLF4JLocationAwareLog.warn(SLF4JLocationAwareLog.java:185)<br>
    ...<br>
</p>
<p><br>
</p>
<p><br>
</p>
<p><br>
</p>
<p>I have attached the logging configuration from the Virgo server. It's called serviceability.xml. (That's the default configuration file name for the Virgo server.)</p>
<p><br>
I'm sorry the mail turned out so long. I hope this will not discourage you from reading it. I will be extremely grateful if you, guys, can help us figure out what makes Logback go crazy.</p>
</div>
</body>
</html>