我正在開發一個新項目並嘗試首次使用Gradle。該應用程序是一個Web應用程序,所以我已經在我的gradle.build
頂部配置的war
和jetty
插件:任務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
我不知道答案,但這個線程 - 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。一些評論可能有一個解決方法。 –
@MichaelEaster非常感謝那個鏈接。我相信這是同一個問題。不幸的是,唯一真正的建議解決方法(編寫自己的插件)現在有點超出了我的Gradle知識。我會等待看看其他人是否響應,然後繼續在我的示例項目中使用logback。 –