<div dir="ltr">Hi Gena,<div><br></div><div>Again, I agree with most of your points at a high-level and don't doubt that your solution can work.</div><div><br></div><div>I do disagree with your comment about the main requirement of logging subsystems: it does depend on application requirements. For instance, in my application, speed is of utmost importance - I am willing to lose debug and warning messages in favor of keeping application performance at its maximum. The only messages that require full reliability for my application are warning and error events (this model is supported by AsyncAppender's current design with its discardingThreshold).</div>
<div><br></div><div>All that being said, I'm not quite sure why you are resistant to a framework for implementing shutdown hooks. Is there a particular reason you object to the user being able to select which shutdown mechanism should be employed by Logback? I understand that you feel your solution covers most or all cases, but is it not possible that the end user of Logback may disagree and prefer to apply their own shutdown procedure or policy? </div>
<div><br></div><div>As a side question, how long would you estimate it would take to modify logback-core (and/or the other logback components) to implement your proposed solution? Are you currently working on implementing this switchToFailSafe functionality or are you proposing that someone else from the logback community develop it? </div>
<div><br></div><div>Thanks!</div><div><br></div><div>Regards,</div><div><br></div><div>Mike Reinhold</div><div><br></div><div><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Mar 20, 2014 at 6:00 AM, Gena Makhomed <span dir="ltr"><<a href="mailto:gmm@csdoc.com" target="_blank">gmm@csdoc.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">On 20.03.2014 2:45, Michael Reinhold wrote:<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I feel like we are speaking past each other a little bit in that I am<br>
not proposing any of the specific shutdown hooks discussed so far at a<br>
theoretical level (without being fully thought through or developed,<br>
they are of course flawed). Rather, I am proposing that my solution be<br>
implemented as a framework for Logback, contributors to Logback, and/or<br>
end users of Logback to build shutdown hooks that fulfill specific<br>
needs. Some of the theoretical hooks discussed could be implemented,<br>
knowing that they are not general solutions, but rather niche solutions<br>
that may be acceptable for some applications. Then, leveraging Logback's<br>
community of contributors (including you and me), more general solutions<br>
can be developed and included as part of Logback.<br>
</blockquote>
<br></div>
framework for logback shutdown hooks just not need at all,<br>
if only two simple solutions cover all possible use cases:<br>
<br>
1) LoggerContext.stop for case app shutdown without JVM shutdown<br>
2) LoggerContext.switchToFailSafe for case app shutdown == JVM shutdown<br>
<br>
register logback shutdown hook, which switch logback from "normal"<br>
to "failsafe" mode have sense even for web-applications, because<br>
tomcat can be stopped via signal SIGTERM, and such shutdown hook<br>
will flush all AsyncAppenders and FileAppenders memory bufffers.<br>
<br>
so, it is even not need any configuration option for enabling such<br>
logback shutdown hook, it should be enabled always for all contexts.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Based on this back and forth discussion, I don't think there is any<br>
resistance to your proposed solution as it has the potential to be a<br>
reasonably generic shutdown hook that could be applicable to many common<br>
use cases.<br>
</blockquote>
<br></div>
can you provide any case in which my proposed solution not applicable?<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Furthermore, it could be implemented as one of the pluggable<br>
classes usable by the ShutdownHookAction.<br>
</blockquote>
<br></div>
java code is trivial: run(){ LoggerContext.<u></u>switchToFailSafeMode(); }<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
If your implementation is as<br>
generic and effective in practice as you have described, it could<br>
actually be the default ShutdownHook implementation. If for some reason<br>
a user found that your solution was non-optimal for their application,<br>
they could implement (or work with the Logback community to implement)<br>
an alternate ShutdownHook that does meet their needs.<br>
</blockquote>
<br></div>
right now exists only three available alternatives:<br>
<br>
1. do nothing and lost all event in various memory buffers<br>
2. use LoggerContext.stop and lost all events after stopping<br>
3. use LoggerContext.<u></u>switchToFailSafeMode for maximum reliability<br>
<br>
can you provide any other alternatives for these three?<br>
<br>
if even theoretically other possible use cases not exists here,<br>
may be not need implement framework for alternatives right now?<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
I hope this helps explain my position adequately - I don't see our two<br>
solutions as competing alternatives, but rather as complimentary<br>
components of the shutdown cleanup functionality of Logback.<br>
</blockquote>
<br></div>
I am talking not about only shutdown cleanup, I propose more generic<br>
solution, just add new, fail-safe mode. Switching logback to fail-safe<br>
mode useful in logback shutdown hook to prevent messages lost,<br>
and also switching logback into fail-safe mode will be useful<br>
for low-memory conditions.<br>
<br>
for example, we have one huge desktop application with many plugins.<br>
I wrote memory monitor, which continuously monitor java heap size,<br>
and continuously provide "live set" size of java objects in heap.<br>
also this monitor have "low memory" handler, which called in case<br>
if free heap memory (max heap memory - live set size) less then 50 MiB.<br>
("live set" size == min used heap size for rolling window of last 5 min)<br>
<br>
switching logback into fail-safe mode will be very useful<br>
for this handler too, for preventing logback events lost in case<br>
if application will be stopped via forthcoming OutOfMemoryError.<br>
<br>
if AsyncAppenders not used and all FileAppenders configured with<br>
"immediateFlush = true" mode - for this special case "normal"<br>
and "fail-safe" mode will be identical. for other cases - not.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
My portion<br>
provides a framework for creating shutdown hooks that cleanup the<br>
Logback context (possibly including some simple implementations) and<br>
your portion includes a more complex, but fairly general implementation<br>
of that shutdown hook framework. This gives us the best of both worlds -<br>
the flexibility to plug different hooks in if needed as well as a solid<br>
default implementation that should cover most use cases.<br>
</blockquote>
<br></div>
There exists only one way for<br>
"cleanup the Logback context" - just call LoggerContext.stop method.<br>
<br>
there is only one question - when do this cleanup. and only one strict<br>
answer, when LoggerContext.stop is required: this is case if application<br>
shutdown != JVM shutdown. In other cases "cleanup the Logback context"<br>
is not required at all, and switching logback into fail-safe mode<br>
is always better approach, because it prevent undesirable events lost.<br>
<br>
if user required to stop logging before actual JVM shutdown<br>
- they always can manually call LoggerContext.stop in own code.<br>
<br>
again, no need any special framework, LoggerContext.stop already exists.<br>
<br>
what you really need - it is configurable timeout<br>
for stopping AsyncAppender worker thread, if AsyncAppender<br>
used as frontend for appender working with remote logging service<br>
and because now in logback not exists any way for making reliable<br>
logging to remove/cloud logging services without log events lost.<br>
<br>
partial solution of remote logging is to play with timeout value<br>
and try to find acceptable tradeoff between application shutdown speed<br>
and application event lost rate from memory buffer on app shutdown.<br>
<br>
optimal solution - just create reliable async appender for remote<br>
services, which buffer events on disk and provides fast application<br>
shutdown and also provides reliable events delivery to remote logging<br>
service even in cases of partial network troubles/failures/overloads.<br>
<br>
main requirement for any logging subsystem: do not lost messages.<br>
all other wishes (speed,usability,etc) is secondary requirements.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
This would seem<br>
to fit with the methodology of design that Logback generally uses where<br>
multiple implementations are possible and generally speaking a few<br>
options are included in the library, but a default implementation that<br>
covers most scenarios is also included in the library and, unless<br>
specified otherwise, is the preferred option.<br>
</blockquote>
<br></div>
I can't imagine how multiple implementations of shutdown hook<br>
can better help prevent event lost if already exists almost<br>
perfect and safe algorithm for graceful shutdown of logback<br>
with minimal possible events lost via new "fail-safe" mode.<div class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Once again, thank you for the good discussion!<br>
</blockquote>
<br></div>
You are welcome!<div class="HOEnZb"><div class="h5"><br>
<br>
-- <br>
Best regards,<br>
 Gena<br>
______________________________<u></u>_________________<br>
Logback-user mailing list<br>
<a href="mailto:Logback-user@qos.ch" target="_blank">Logback-user@qos.ch</a><br>
<a href="http://mailman.qos.ch/mailman/listinfo/logback-user" target="_blank">http://mailman.qos.ch/mailman/<u></u>listinfo/logback-user</a><br>
</div></div></blockquote></div><br></div>