Log4j2 не пишет в файл журнала и не создает его - PullRequest
0 голосов
/ 12 июня 2018

Я знаю, что вопрос задавался ранее, однако я все еще не могу получить log4j2 для записи в файл (файл даже не создан).Однако он отображается на консоли.

Я поместил log4j2.xml в src / main / resources:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
        </Console>
        <File name="MyFile" fileName="error.log" immediateFlush="false"
            append="false">
            <PatternLayout
                pattern="%d{yyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
        </File>
    </Appenders>
    <Loggers>
        <Root level="all">
            <AppenderRef ref="Console" />
            <AppenderRef ref="MyFile" />
        </Root>
    </Loggers>
</Configuration>

Мой основной метод, который вызывает функцию ведения журнала

@SpringBootApplication
public class SpringApplication1 {


    public static final Logger logger = LogManager.getLogger(SpringApplication1.class);
    public static void main(String[] args) {

        SpringApplication.run(SpringApplication1.class, args);
        logger.info("testing info");
        logger.error("this is an error");

    }

У меня есть две зависимости в моем pom.xml

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

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

1 Ответ

0 голосов
/ 12 июня 2018

spring-jcl должен находиться на пути к классам.

Механизм регистрации по умолчанию в Spring Boot - это logback.

Одним из способов является использование Spring Boot Log4j Starter .Чтобы использовать log4j, logback должен быть исключен:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<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>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
...