2014-09-05 10 views
13

Używam spring-boot-starter i chcę skonfigurować log4j2.xml, aby logować asynchron + inną zawartość do różnych plików dziennika.Rejestrowanie rozruchowe z log4j2?

Utworzono plik log4j2, ale Spring nadal korzysta z domyślnego rejestrowania rozruchu sprężyny rozruchowej. Jak mogę przełączyć rejestrowanie?

Odpowiedz

37

mam lepszy sposób:

  1. Wykluczyć logback Rejestrator:

    <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. Dodaj log4j2 rozruchu rozrusznik:

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

Źródło: http://docs.spring.io/spring-boot/docs/1.5.1.RELEASE/reference/htmlsingle/#howto-configure-log4j-for-logging

Ciesz się!

+0

Myślę, że miałeś na myśli: "1. wykluczyć framework logback" zamiast "wykluczyć logger slf4j", prawda? –

+0

@DanielMarcotte w prawo! – kles4eko

+0

Edytowałem tak, aby inni nie wpadli w zakłopotanie. –

9

Spróbuj:

  1. Wykluczenie sprężyna rozruchu rozrusznik wspomagane np

    <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. Dodaj zależności dla swojego interfejsu logowania, np. slf4j

    <dependency> 
        <groupId>org.apache.logging.log4j</groupId> 
        <artifactId>log4j-slf4j-impl</artifactId> 
        <version>2.0.2</version> 
    </dependency> 
    
  3. Dodaj inne implementacje rejestrowania wskazujące wybrany interfejs logowania, np.

    <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. Dodaj swoją docelową implementację logowania, np.

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

i powinno działać.

+5

Obecnie istnieje również 'wiosna-rozruchu starter-log4j2' od wiosny-boot-1.2.0.RELEASE. Tylko w celach informacyjnych. – membersound

+0

Nie działa to również dla mnie: wszystkie dzienniki są drukowane na konsoli. – Denys

0

To właśnie dla mnie zadziałało. Uwzględniając dwa dodatkowe wykluczenia. Aplikacja nie została jeszcze zbierając log4j i została miał konflikt

Rzeczywista wiążąca jest typu [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> 
Powiązane problemy