私のロギングは私の演奏コードからうまく機能していますが、私が持っているakkaコードはファイル/ stdoutにロギングしていません。私のakkaロギングが演奏の中で動作しない理由
class EmailActor extends Actor with ActorLogging {
import EmailActor._
log.info("email actor hatched..")
...
}
このアクターを作成すると、ログファイルまたは標準出力のログエントリが表示されません。
私はこのベーターテンプレートからデフォルトのapplication.confを持っている:https://github.com/playframework/play-scala/blob/master/conf/logback.xml
は、私はいくつかのAkkaのラベルと私のlogbackファイルを変更する必要がありますか?私はこれを追加した私の依存関係で
akka {
loggers = ["akka.event.slf4j.Slf4jLogger"]
#loggers = ["akka.event.Logging$DefaultLogger"]
loglevel = "DEBUG"
logging-filter = "akka.event.slf4j.Slf4jLoggingFilter"
actor {
debug {
lifecycle = on
}
}
}
(および両方私のプレイのアプリのDEPに追加されます):
アップデートは
私はapplication.confで、今これを行っている
val akkaSlf4j = "com.typesafe.akka" %% "akka-slf4j" % Version.akkaSlf4j
val logback = "ch.qos.logback" % "logback-classic" % Version.logback
私logback.xmlは、次のようになります。
<!-- https://www.playframework.com/documentation/latest/SettingsLogger -->
<configuration>
<conversionRule conversionWord="coloredLevel" converterClass="play.api.libs.logback.ColoredLevel" />
<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<file>${application.home:-.}/logs/application.log</file>
<encoder>
<pattern>%date [%level] from %logger in %thread - %message%n%xException</pattern>
</encoder>
</appender>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%coloredLevel %logger{15} - %message%n%xException{10}</pattern>
</encoder>
</appender>
<appender name="ASYNCFILE" class="ch.qos.logback.classic.AsyncAppender">
<appender-ref ref="FILE" />
</appender>
<appender name="ASYNCSTDOUT" class="ch.qos.logback.classic.AsyncAppender">
<appender-ref ref="STDOUT" />
</appender>
<logger name="play" level="INFO" />
<logger name="application" level="DEBUG" />
<!-- Off these ones as they are annoying, and anyway we manage configuration ourselves -->
<logger name="com.avaje.ebean.config.PropertyMapLoader" level="OFF" />
<logger name="com.avaje.ebeaninternal.server.core.XmlConfigLoader" level="OFF" />
<logger name="com.avaje.ebeaninternal.server.lib.BackgroundThread" level="OFF" />
<logger name="com.gargoylesoftware.htmlunit.javascript" level="OFF" />
<root level="WARN">
<appender-ref ref="ASYNCFILE" />
<appender-ref ref="ASYNCSTDOUT" />
</root>
</configuration>
STDOUTまたはActorLoggingログメソッドを使用して作成したログファイルにakka関連のログは表示されません。
を追加し、デフォルトのログレベルが
WARN
に設定されていることかもしれないですakkaのライフサイクルログなどを見ることができます。しかし、アクターにActorLoggingを使用し、log.debug( "hello")を使用すると、STDOUTまたはログファイルに表示されません。 – Blankman
@Blankmanあなたは私の更新された答えを見ることができます –
ちょうど私が理解しているのは、上のSTDOUTはakkaロギングを出力していますが、私自身のログステートメントをSTDOUTに表示するには、SLF4Jが必要ですか? – Blankman