2014-09-05 24 views
13

Sto utilizzando spring-boot-starter e desidero configurare log4j2.xml per registrare asincron + contenuto diverso su file di registro diversi.Registrazione Spring-Boot con log4j2?

Ho creato il file log4j2, ma Spring utilizza ancora la registrazione predefinita spring-boot. Come posso cambiare la registrazione?

risposta

37

Ho un modo migliore:

  1. Escludi logback logger:

    <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. Aggiungi avvio log4j2 avviamento:

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

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

Buon divertimento!

+0

Penso che intendessi: "1. escludi logback framework" invece di "exclude logger slf4j" giusto? –

+0

@DanielMarcotte giusto! – kles4eko

+0

Ho modificato solo così le altre persone non si confondono. –

9

Prova questo:

  1. Esclusione molla-boot-starter-logging esempio

    <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. Aggiungi dipendenze per l'interfaccia di registrazione per esempio slf4j

    <dependency> 
        <groupId>org.apache.logging.log4j</groupId> 
        <artifactId>log4j-slf4j-impl</artifactId> 
        <version>2.0.2</version> 
    </dependency> 
    
  3. Aggiungere altre implementazioni di registrazione indicando scelto accedendo all'interfaccia esempio

    <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. Aggiungere l'implementazione di registrazione di destinazione per esempio

    <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> 
    

e dovrebbe funzionare.

+5

Al giorno d'oggi c'è anche 'primavera-boot starter-log4j2' da spring-boot-1.2.0.RELEASE. Solo per riferimento – membersound

+0

Questo non funziona anche per me: tutti i registri sono in stampa su console. – Denys

0

Questo è ciò che ha funzionato per me. Avere due ulteriori esclusioni. Else applicazione non è stata ripresa log4j e si ebbe conflitto

effettivo legame è di tipo [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>