web-dev-qa-db-ja.com

Akka SLF4Jログバックの構成と使用法

Akkaアプリケーションのロギングを設定するために、次の手順を実行しました。

  • application.confファイルを作成し、src/main/resourcesに配置しました。それは次のようになります:

    
        akka { 
          event-handlers = ["akka.event.slf4j.Slf4jEventHandler"] 
          loglevel = "INFO"
        }
    
  • logback.xmlファイルを作成し、src/main/resourcesに配置しました。それは次のようになります:

    <configuration>
    
      <appender name="FILE" class="ch.qos.logback.core.fileappender">
        <File>./logs/akka.log</File>
        <encoder>
          <pattern>%d{HH:mm:ss.SSS} [%-5level] %msg%n</pattern>
        </encoder>
      </appender>
    
      <root level="info">
        <appender-ref ref="FILE" />
      </root>
    
    </configuration>
    
  • 以下を.scala sbtビルドファイルに追加しました:


    libraryDependencies += "com.typesafe.akka" % "akka-slf4j" % "2.0.3", libraryDependencies += "ch.qos.logback" % "logback-classic" % "1.0.9" lazy val logback = "ch.qos.logback" % "logback-classic" % "1.0.9"
  • このコードをログに記録しようとしました:

    
        import akka.event.Logging
    val log = Logging(context.system, this) log.info("...")

私が得ているのは、標準出力のログであり、ログを使用したログファイルの作成はありません。

ステップを逃しましたか?または何か間違って設定しましたか?

27
Apple Pie

この配置では、akka.event.Loggingを使用できます。SLF4Jインスタンスを指定する必要はありません。

(2013年12月13日テスト済み)

コンソールログとファイルへのログを取得します。これが組み込みのロガーではないことを証明するために、ここで説明するように、%X {akkaTimestamp}を含めるように変更しました。

http://doc.akka.io/docs/akka/snapshot/scala/logging.html

build.sbt

library dependencies: (Akka version 2.2.3)

...
"com.typesafe.akka" %% "akka-slf4j" % "2.2.3"
"ch.qos.logback" % "logback-classic" % "1.0.9"
...

src/main/resources/application.conf

akka {
  loggers = ["akka.event.slf4j.Slf4jLogger"]
  loglevel = "INFO"
}

src/main/resources/logback.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <target>System.out</target>
        <encoder>
            <pattern>%X{akkaTimestamp} %-5level[%thread] %logger{0} - %msg%n</pattern>
        </encoder>
    </appender>

    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <file>log/akka.log</file>
        <append>false</append>
        <encoder>
            <pattern>%date{yyyy-MM-dd} %X{akkaTimestamp} %-5level[%thread] %logger{1} - %msg%n</pattern>
        </encoder>
    </appender>

    <logger name="akka" level="INFO" />

    <root level="DEBUG">
        <appender-ref ref="CONSOLE"/>
        <appender-ref ref="FILE"/>
    </root>

</configuration>

この配置は、ActorLoggingミックスインを使用し、Loggingを直接作成する場合にも機能します。

import akka.event.Logging

val log = Logging(context.system, classOf[NameOfYourActor])

log.info("good luck!")
26
reggoodwin

私もこの問題に遭遇しましたが、私の場合はクラスパスの問題ではありませんでした。

私はakka.event.Loggingをcom.typesafe.scalalogging.slf4j.Loggingに置き換えました。

私のlogback.xml(main/resourceの下):

<configuration>
  <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>logs/filename.log</file>
    <encoder>
      <pattern>%date %level %msg%n</pattern>
    </encoder>
    <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
      <maxIndex>10</maxIndex>
      <FileNamePattern>logs/filename.log.%i.gz</FileNamePattern>
    </rollingPolicy>
    <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
      <maxFileSize>20MB</maxFileSize>
    </triggeringPolicy>
  </appender>
  <root level="info">
    <appender-ref ref="FILE" />
  </root>
</configuration>

私のpom.xml:

<dependency>
  <groupId>com.typesafe</groupId>
  <artifactId>scalalogging-slf4j_2.10</artifactId>
  <version>1.0.1</version>
</dependency>
<dependency>
  <groupId>ch.qos.logback</groupId>
  <artifactId>logback-classic</artifactId>
  <version>1.0.13</version>
</dependency>

そしてコードで:

import com.typesafe.scalalogging.slf4j.Logging

class LoggingService extends Actor with Logging {
  // use logger.info() etc.
}

(application.confを使用しませんでした)

4
some some

このapplication.confを使用してみてください:

akka {
  loggers = ["akka.event.slf4j.Slf4jLogger"]
  loglevel = "DEBUG"
  logging-filter = "akka.event.slf4j.Slf4jLoggingFilter"
}

また、ファイルアペンダーのlogback構成にクラス名が間違っている可能性があることにも気付きました。 <appender name="FILE" class="ch.qos.logback.core. fileappender">がありますが、<appender name="FILE" class="ch.qos.logback.core.FileAppender">である必要があります。

別の問題は、ファイルへのパスである可能性があります。相対パスではなく絶対パスを使用してみてください。 <file>/absolute/path/testFile.log</file>

ログバックのバージョンを1.2.3に変更することもできます。 sl4jの設定に関するakkaのドキュメントを次に示します。 link

2
Kirill Yankov

セットアップで変更するのは、 weiglewilczek slf4jアダプター を追加することだけです。

次の設定で問題なく動作します。

akka {
  event-handlers = ["akka.event.slf4j.Slf4jEventHandler"]
  loglevel = DEBUG
}

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>log/app.log</file>

        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>log/app.%d{dd-MM-yyyy}.log</fileNamePattern>
            <maxHistory>60</maxHistory>
        </rollingPolicy>

        <encoder>
            <pattern>%d [%thread] [%class] %5p - %m%n</pattern>
        </encoder>
    </appender>

    <root level="INFO">
        <appender-ref ref="FILE"/>
    </root>
</configuration>

trait test extends com.weiglewilczek.slf4s.Logging {
  def logIt() {
    logger.info("this logs fine")
  }
}
1
iwein