【问题标题】:Spring boot using slf4j no log file created使用 slf4j 的 Spring Boot 没有创建日志文件
【发布时间】:2018-11-28 13:03:49
【问题描述】:

我有一个 Spring Boot 应用程序,尝试按照 https://www.baeldung.com/spring-boot-logging 的教程使用 slf4j,但是日志仅在控制台端打印。在给定目录/var/logs 中没有创建日志文件。

log4j2-spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout
                    pattern="%style{%d{ISO8601}}{black} %highlight{%-5level }[%style{%t}{bright,blue}] %style{%C{1.}}{bright,yellow}: %msg%n%throwable" />
        </Console>

        <RollingFile name="RollingFile"
                     fileName="/var/logs/spring-boot-logger-log4j2.log"
                     filePattern="/var/logs/$${date:yyyy-MM}/spring-boot-logger-log4j2-%d{-dd-MMMM-yyyy}-%i.log.gz">
            <PatternLayout>
                <pattern>%d %p %C{1.} [%t] %m%n</pattern>
            </PatternLayout>
            <Policies>
                <!-- rollover on startup, daily and when the file reaches
                    10 MegaBytes -->
                <OnStartupTriggeringPolicy />
                <SizeBasedTriggeringPolicy
                        size="10 MB" />
                <TimeBasedTriggeringPolicy />
            </Policies>
        </RollingFile>
    </Appenders>

    <Loggers>
        <!-- LOG everything at INFO level -->
        <Root level="info">
            <AppenderRef ref="Console" />
            <AppenderRef ref="RollingFile" />
        </Root>

        <Logger name="com.buraktas">
            <AppenderRef ref="LogFile"/>
            <AppenderRef ref="Console"/>
        </Logger>
    </Loggers>

</Configuration>

maven 依赖

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

【问题讨论】:

  • 你可以看看这个帖子,很有用:stackoverflow.com/a/45051211/4373948
  • 是的,我也尝试了这些示例,但没有运气。另一方面,在那个例子中,他们使用 logback 我试图使用 slf4j
  • 好的,你把 log4j2-spring.xml 放在哪里?
  • resources目录下。
  • LogFile 用于com.buraktas 记录器和RollingFile 用于根记录器是否正确?

标签: java spring-boot slf4j


【解决方案1】:

您可以在application.properties文件中定义日志路径,例如查看以下链接:

logging.level.com.example.springscheduler = debug
logging.level.org.springframework.web = WARN
logging.file.name =log/loggingdemocontroller.log

https://springbootmvc.blogspot.com/2020/06/spring-boot-logging-using-orgslf4jlogger.html

【讨论】:

    【解决方案2】:

    我发现了 spring-boot-starterspring-boot-starter-web 依赖项的问题。我仅从其中一个中排除了 spring-boot-starter-logging 依赖项,这迫使 spring 使用 logback 记录器。而且由于 logback 记录器没有为其配置选择log4j2.xml,因此我们没有创建任何文件。所以 pom.xml 文件是这样的;

    <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <version>2.1.0.RELEASE</version>
    </dependency>
    
    <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-web -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>2.1.0.RELEASE</version>
        <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>
    

    我还需要从 spring-boot-starter 依赖项中排除 spring-boot-starter-logging。好吧,毕竟因为我有spring-boot-starter-web 我只是删除了spring-boot-starter 包,这是不必要的。

    【讨论】:

      猜你喜欢
      • 2019-04-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-06-03
      • 1970-01-01
      • 2019-08-25
      • 2017-05-08
      • 1970-01-01
      相关资源
      最近更新 更多