私は新しいプロジェクトに取り組み、初めてGradleを使用しようとしています。私のコードでslf4jとlog4jを使用したjettyRunWarタスクはエラーになります。ログにlog4jを使用するにはどうすればよいですか?
apply plugin: 'war'
apply plugin: 'jetty'
を私はロギング用Apache Commons Logging APIするプログラム:アプリケーションは、私は私のgradle.build
の上部にwar
とjetty
プラグインを設定しているWebアプリケーションです。私の依存関係の1つ(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
を使用して自分のアプリケーションを実行し、サーブレットが実行を
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
ディレクトリです。 Jettyを起動するときにGradleが独自のクラスパスを含むことは可能でしょうか?
これを防ぐ方法はありますか?
解説の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の知識を少し超えています。他の誰かが応答したかどうかを確認し、今のところ私のサンプルプロジェクトでログバックを続けていきます。 –