[英]coudnt use logback because of log4j
嗨我有logback和slf4j的問題,即時編寫簡單的應用程序,后來在jar中打包,我想添加使用logback日志記錄
我正在使用:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.7</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-client</artifactId>
<version>5.8.0</version>
</dependency>
<dependency>
<groupId>com.mchange</groupId>
<artifactId>c3p0</artifactId>
<version>${c3p0.version}</version>
</dependency>
<dependency>
<groupId>commons-pool</groupId>
<artifactId>commons-pool</artifactId>
<version>${commons.pool.version}</version>
</dependency>
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>${postgresql.version}</version>
</dependency>
<dependency>
<groupId>net.sf.ehcache</groupId>
<artifactId>ehcache</artifactId>
<version>${ehcache.version}</version>
</dependency>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>${gson.version}</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>${jedis.version}</version>
</dependency>
在主要我有:
LoggerContext loggerContext = (LoggerContext) LoggerFactory.getILoggerFactory();
JoranConfigurator configurator = new JoranConfigurator();
configurator.setContext(loggerContext);
configurator.doConfigure(logbackFile)
它用於在jar文件之外加載logback.xml配置
最有趣的是,這個程序正在本地機器上運行(Windows)(讀取logback.xml,創建文件,寫入文件)但是當我將它上傳到遠程服務器(linux)時我有奇怪的錯誤
Exception in thread "main" java.lang.ClassCastException: org.slf4j.impl.Log4jLoggerFactory cannot be cast to ch.qos.logback.classic.LoggerContext
問題是他為什么要從org.slf4j.impl轉換ch.qos.logback.classic.LoggerContext。 Log4jLoggerFactory ??
我沒有任何任何lib4j的lib ...我的意思是我沒有在整個機器上
一個額外的信息:在Windows上我有來自Oracle和Linux的Java我有openjdk - 這可能是個問題?
// =================依賴樹
[INFO] +- org.apache.activemq:activemq-client:jar:5.8.0:compile
[INFO] | +- org.apache.geronimo.specs:geronimo-jms_1.1_spec:jar:1.1.1:compile
[INFO] | +- org.fusesource.hawtbuf:hawtbuf:jar:1.9:compile
[INFO] | \- org.apache.geronimo.specs:geronimo-j2ee-management_1.1_spec:jar:1.0.1:compile
[INFO] +- com.mchange:c3p0:jar:0.9.2-pre6:compile
[INFO] | \- com.mchange:mchange-commons-java:jar:0.2.3.1:compile
[INFO] +- commons-pool:commons-pool:jar:1.6:compile
[INFO] +- postgresql:postgresql:jar:9.1-901.jdbc4:compile
[INFO] +- net.sf.ehcache:ehcache:jar:2.9.0:compile
[INFO] +- com.google.code.gson:gson:jar:2.2.4:compile
[INFO] +- redis.clients:jedis:jar:2.1.0:compile
[INFO] +- org.slf4j:slf4j-api:jar:1.7.5:compile
[INFO] +- ch.qos.logback:logback-classic:jar:1.1.3:compile
[INFO] +- ch.qos.logback:logback-core:jar:1.1.3:compile
[INFO] \- junit:junit:jar:4.11:test
[INFO] \- org.hamcrest:hamcrest-core:jar:1.3:test
由於SLF4J已經存在於項目或其他一些繼承項目中,因此在運行時可能會發生沖突。 添加到我的POM
文件的排除對我POM
:
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
基於它在這里所說的內容: https : //github.com/dropwizard/dropwizard/issues/1205 ,初始化庫存在競爭條件。 我遇到了類似的問題,我的程序在NetBeans上運行良好,但在gnome終端中無效。 競爭條件解釋了多種情況下常見的不一致行為。 我不完全理解為什么會發生這種情況,但這里有針對特定情況的解決方法: https : //gist.github.com/mbknor/34944ea4589a5fc6974c 。 這個例子來自該鏈接,它可能不適用於上面提到的特定情況,但如果您了解正在發生的事情,可能很容易適應特定情況。
static {
System.out.println("Waiting for slf4j to finish initialization");
while ( LoggerFactory.getILoggerFactory() instanceof SubstituteLoggerFactory){
try {
Thread.sleep(50);
} catch (InterruptedException e) {
break;
}
}
}
試圖取出依賴
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.7</version>
</dependency>
此依賴關系包含在
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.3</version>
</dependency>
正如您在logback-classic pom文件中看到的那樣 - http://central.maven.org/maven2/ch/qos/logback/logback-classic/1.1.3/logback-classic-1.1.3.pom
還要確保在初始化記錄器時對其進行建模
private static final Logger LOG = LoggerFactory
.getLogger(ClassName.class)
我不得不在控制器中切換記錄器:
private static final Logger log = LogbackUtil.getLogger( MyController.class );
至
private static final Logger log = LoggerFactory.getLogger( MyController.class );
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.