2016-08-16 17 views
0

私は新しいプロジェクトに取り組み、初めてGradleを使用しようとしています。私のコードでslf4jとlog4jを使用したjettyRunWarタスクはエラーになります。ログにlog4jを使用するにはどうすればよいですか?

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

を私はロギング用Apache Commons Logging APIするプログラム:アプリケーションは、私は私のgradle.buildの上部にwarjettyプラグインを設定している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 
+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の知識を少し超えています。他の誰かが応答したかどうかを確認し、今のところ私のサンプルプロジェクトでログバックを続けていきます。 –

答えて

3

私はGradle 3.0がリリースされたことを見ただけで、私の質問を投稿した後。リリースノートでは、jettyプラグインは廃止予定であり、Grettyを使用する必要があります。

Gradle 3.0にアップグレードし、Grettyを使用して問題を修正しました。

ウェブアプリケーションのランタイムパスにjettyプラグインにGradleのクラスパスが含まれているということは、jettyプラグインの動作に問題があり、修正されないようです。

関連する問題