2014-09-05 12 views
13

Ich benutze spring-boot-starter, und würde gerne log4j2.xml konfigurieren, asynchron + verschiedenen Inhalt zu verschiedenen Logfiles zu loggen.Spring-Boot-Protokollierung mit log4j2?

Ich habe die log4j2-Datei erstellt, aber Spring verwendet immer noch die Spring-Boot-Standardprotokollierung. Wie kann ich die Protokollierung wechseln?

Antwort

37

Ich habe einen besseren Weg:

  1. logback Logger ausschließen:

    <dependency> 
        <groupId>org.springframework.boot</groupId> 
        <artifactId>spring-boot-starter</artifactId> 
        <exclusions> 
         <exclusion> 
          <groupId>org.springframework.boot</groupId> 
          <artifactId>spring-boot-starter-logging</artifactId> 
         </exclusion> 
        </exclusions> 
    </dependency> 
    
  2. hinzufügen log4j2 Boot-Starter:

    <dependency> 
        <groupId>org.springframework.boot</groupId> 
        <artifactId>spring-boot-starter-log4j2</artifactId> 
    </dependency> 
    

Quelle: http://docs.spring.io/spring-boot/docs/1.5.1.RELEASE/reference/htmlsingle/#howto-configure-log4j-for-logging

Genießen Sie!

+0

Ich denke, du meintest: "1. logback Framework ausschließen" statt "ausschließen slf4j Logger" richtig? –

+0

@DanielMarcotte richtig! – kles4eko

+0

Ich habe gerade bearbeitet, damit andere Leute nicht verwirrt werden. –

9

Versuchen Sie folgendes:

  1. ausschließen Feder-boot-Starter-logging z.B.

    <dependency> 
        <groupId>org.springframework.boot</groupId> 
        <artifactId>spring-boot-starter</artifactId> 
        <exclusions> 
         <exclusion> 
          <groupId>org.springframework.boot</groupId> 
          <artifactId>spring-boot-starter-logging</artifactId> 
         </exclusion> 
        </exclusions> 
    </dependency> 
    
  2. Fügen Sie Abhängigkeiten für Ihre Protokollierungsschnittstelle hinzu, z. slf4j

    <dependency> 
        <groupId>org.apache.logging.log4j</groupId> 
        <artifactId>log4j-slf4j-impl</artifactId> 
        <version>2.0.2</version> 
    </dependency> 
    
  3. hinzufügen andere Logging-Implementierungen die Protokollierung ausgewählt Zeige Schnittstelle z

    <dependency> 
        <groupId>org.slf4j</groupId> 
        <artifactId>jcl-over-slf4j</artifactId> 
    </dependency> 
    <dependency> 
        <groupId>org.slf4j</groupId> 
        <artifactId>jul-to-slf4j</artifactId> 
    </dependency> 
    <dependency> 
        <groupId>org.slf4j</groupId> 
        <artifactId>log4j-over-slf4j</artifactId> 
    </dependency> 
    
  4. Ihre Ziel Protokollierung Implementierung hinzufügen z.B.

    <dependency> 
        <groupId>org.apache.logging.log4j</groupId> 
        <artifactId>log4j-api</artifactId> 
        <version>2.0.2</version> 
    </dependency> 
    <dependency> 
        <groupId>org.apache.logging.log4j</groupId> 
        <artifactId>log4j-core</artifactId> 
        <version>2.0.2</version> 
    </dependency> 
    

Und sollte es funktionieren.

+5

Heutzutage gibt auch ist 'feder Boot- hatte starter-log4j2' seit Frühjahr-boot-1.2.0.RELEASE. Nur als Referenz. – membersound

+0

Dies funktioniert auch nicht für mich: Alle Protokolle werden auf der Konsole gedruckt. – Denys

0

Das hat bei mir funktioniert. Mit zwei zusätzlichen Ausnahmen. Else Die Anwendung wurde nicht Kommissionierung log4j und wurde Konflikt

tatsächliche Bindung vom Typ [ch.qos.logback.classic.util.ContextSelectorStaticBinder]

<dependency> 
    <groupId>org.mybatis.spring.boot</groupId> 
    <artifactId>mybatis-spring-boot-starter</artifactId> 
    <version>1.0.0</version> 
    <exclusions> 
     <exclusion> 
      <groupId>org.springframework.boot</groupId> 
      <artifactId>spring-boot-starter-logging</artifactId> 
     </exclusion> 
     <exclusion> 
      <artifactId>logback-classic</artifactId> 
      <groupId>ch.qos.logback</groupId> 
     </exclusion> 
     <exclusion> 
      <artifactId>log4j-over-slf4j</artifactId> 
      <groupId>org.slf4j</groupId> 
     </exclusion>    
    </exclusions>   
</dependency> 

<dependency> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-log4j2</artifactId> 
</dependency>