[jboss-jira] [JBoss JIRA] Commented: (JBLOGGING-65) JBoss Logging fails to support log4j-over-slf4j
David Lloyd (JIRA)
jira-events at lists.jboss.org
Mon Jun 20 15:15:24 EDT 2011
[ https://issues.jboss.org/browse/JBLOGGING-65?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12609816#comment-12609816 ]
David Lloyd commented on JBLOGGING-65:
--------------------------------------
I think you misunderstand, the two issues you listed are already solved. To route slf4j-based logging to JBoss Logging, you use slf4j-jboss-logging. To route JBoss Logging to slf4j, you must be running logback - the slf4j backend only exists as a means to access logback, that is all; generalized jboss-logging over slf4j is not supported and is not intended to ever be supported. JBoss Logging logs only to backends, not to other logging frontends. It just so happens that slf4j is not just a general logging abstraction, it is also the front-end logging API for logback.
> JBoss Logging fails to support log4j-over-slf4j
> -----------------------------------------------
>
> Key: JBLOGGING-65
> URL: https://issues.jboss.org/browse/JBLOGGING-65
> Project: JBoss Logging
> Issue Type: Bug
> Security Level: Public(Everyone can see)
> Affects Versions: 3.0.0.Beta5-jboss-logging
> Reporter: Jeff Ramsdale
> Assignee: David Lloyd
> Priority: Critical
>
> org.jboss.logging.LoggerProviders tests for the existence of org.apache.log4j.LogManager and if it discovers it assumes Log4j is in use. This is incorrect in the scenario where log4j events are routed to slf4j for eventual routing to another logging engine (a very common use case). This engine may be Logback, but may not. Therefore, the test for whether slf4j is in use is not whether Logback is in the classpath (Logback is AN implementation of slf4j, not THE implementation...), but whether org.slf4j.impl.StaticLoggerBinder is. There should be no attempt to detect Logback itself. JBoss Logging cannot tell through simply loading org.apache.log4j.LogManager whether this class is provided by log4j or by log4j-over-slf4j so cannot use this class to detect log4j use. To clarify, the logic should be:
> 1) If org.slf4j.impl.StaticLoggerBinder is available, use slf4j.
> 2) If org.apache.log4j.LogManager (but not StaticLoggerBinder) is available, use log4j.
> 3) Otherwise use java.util.logging
--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the jboss-jira
mailing list