2016-08-16 38 views
0

我正在開發一個新項目並嘗試首次使用Gradle。該應用程序是一個Web應用程序,所以我已經在我的gradle.build頂部配置的warjetty插件:任務jettyRunWar與slf4j和log4j導致錯誤。我如何使用log4j進行日誌記錄?

apply plugin: 'war' 
apply plugin: 'jetty' 

在我的代碼編程到Apache Commons Logging API進行記錄。我的一個依賴項(OpenSAML)使用SLF4J API進行日誌記錄。我對log4j 1.2最熟悉實際的日誌配置,所以這就是我想用來實際執行日誌記錄。

要配置這些依賴於我的gradle.build文件我有以下幾點:

// Logging API 
compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.21' 
compile group: 'org.slf4j', name: 'jcl-over-slf4j', version: '1.7.21' 

// Logging at runtime 
runtime group: 'org.slf4j', name: 'slf4j-log4j12', version: '1.7.21' 
runtime group: 'log4j', name: 'log4j', version: '1.2.17' 

當我使用指令gradle jettyRunWar我的應用程序並且servlet執行其試圖登錄我收到以下錯誤的東西:

java.lang.ExceptionInInitializerError 
    at org.slf4j.impl.StaticLoggerBinder.<init>(StaticLoggerBinder.java:72) 
    at org.slf4j.impl.StaticLoggerBinder.<clinit>(StaticLoggerBinder.java:45) 
    at org.slf4j.LoggerFactory.bind(LoggerFactory.java:150) 
    at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:124) 
    at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:412) 
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:357) 
    at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:383) 
    at sso.HomePageServlet.<clinit>(HomePageServlet.java:23) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:422) 
    at java.lang.Class.newInstance(Class.java:442) 
    at org.mortbay.jetty.servlet.Holder.newInstance(Holder.java:153) 
    at org.mortbay.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:428) 
    at org.mortbay.jetty.servlet.ServletHolder.getServlet(ServletHolder.java:339) 
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487) 
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:390) 
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216) 
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182) 
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765) 
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:440) 
    at org.mortbay.jetty.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:230) 
    at org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114) 
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152) 
    at org.mortbay.jetty.Server.handle(Server.java:326) 
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542) 
    at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:926) 
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:549) 
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212) 
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404) 
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:410) 
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582) 
Caused by: java.lang.IllegalStateException: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError. See also http://www.slf4j.org/codes.html#log4jDelegationLoop for more details. 
    at org.slf4j.impl.Log4jLoggerFactory.<clinit>(Log4jLoggerFactory.java:54) 
    ... 33 more 

錯誤很明顯,log4j-over-slf4j.jar也在類路徑中。我的應用程序沒有列出這個。使用gradle dependencies --configuration runtime也不會列出這個.jar文件。這個.jar存在的唯一位置在gradle\lib目錄中。 Gradle在啓動Jetty時是否可能包含自己的類路徑?

有什麼辦法可以防止這種情況發生?

解決方案概述here似乎沒有工作。

gradle -v顯示:

------------------------------------------------------------ 
Gradle 2.14.1 
------------------------------------------------------------ 

Build time: 2016-07-18 06:38:37 UTC 
Revision:  d9e2113d9fb05a5caabba61798bdb8dfdca83719 

Groovy:  2.4.4 
Ant:   Apache Ant(TM) version 1.9.6 compiled on June 29 2015 
JVM:   1.8.0_45 (Oracle Corporation 25.45-b02) 
OS:   Windows 7 6.1 amd64 
+2

我不知道答案,但這個線程 - https://discuss.gradle.org/t/slf4j-detected-both-log4j-over-slf4j-jar-and-bound-slf4j-log4j12-jar- on-the-class-path/14067 - 引用了一個似乎打開的問題 - https://issues.gradle.org/browse/GRADLE-897。一些評論可能有一個解決方法。 –

+0

@MichaelEaster非常感謝那個鏈接。我相信這是同一個問題。不幸的是,唯一真正的建議解決方法(編寫自己的插件)現在有點超出了我的Gradle知識。我會等待看看其他人是否響應,然後繼續在我的示例項目中使用logback。 –

回答

3

只是發表我的問題後,我看到Gradle 3.0被釋放。在發行說明中,它說jetty插件已被棄用,並且應該使用Gretty

升級到Gradle 3.0並切換到使用Gretty修復了這個問題。

事實上,jetty插件在您的webapps的運行時路徑中包含Gradle的類路徑,這與jetty插件的工作方式有關,它看起來不會被修復。

相關問題