Web项目

SpringBoot 使用log4j打印日志

2018-11-27  本文已影响0人  weisen

最近需要改造以前的SpringMVC项目,将改为SpringBoot项目,以前的项目打印日志是使用log4j的,但SpringBoot用的默认日志框架是Logback。

一、添加依赖

修改pom.xml文件,过滤掉自带的spring-boot-starter-logging,然后添加spring-boot-starter-log4j依赖包。不过滤掉启动的时候会报错

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

二、添加log4j.properties

在resources目录下新建log4j.properties配置文件, 配置info,error,console,debug四种输出格式。

# 设定logger的root
log4j.rootLogger=info,error,info,warn,stdout
##############打印到平台的日志##################
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}-[%p]-(%C:%L) %m%n
##############WARN打印的文件的日志##################
log4j.appender.warn=cn.com.bluemoon.bd.service.its.deg.common.Log4jMyAppender
log4j.appender.tracking.Encoding=utf-8
log4j.appender.warn.layout=org.apache.log4j.PatternLayout
log4j.appender.warn.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}-[%p]-(%C:%L) %m%n
log4j.appender.warn.File=/data/syslogs/bd_its_deg_logs_sys/warn.log
log4j.appender.warn.DatePattern='.'yyyy-MM-dd
log4j.appender.warn.Threshold=WARN
##############ERROR打印的文件的日志##################
log4j.appender.error=cn.com.bluemoon.bd.service.its.deg.common.Log4jMyAppender
log4j.appender.error.layout=org.apache.log4j.PatternLayout
log4j.appender.error.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}-[%p]-(%C:%L) %m%n
log4j.appender.error.File=/data/syslogs/bd_its_deg_logs_sys/error.log
log4j.appender.error.DatePattern='.'yyyy-MM-dd
log4j.appender.error.Threshold=ERROR
##############INFO打印的文件的日志##################
log4j.appender.info=cn.com.bluemoon.bd.service.its.deg.common.Log4jMyAppender
log4j.appender.info.layout=org.apache.log4j.PatternLayout
log4j.appender.info.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}-[%p]-(%C:%L) %m%n
log4j.appender.info.File=/data/syslogs/bd_its_deg_logs_sys/info.log
log4j.appender.info.DatePattern='.'yyyy-MM-dd
log4j.appender.info.Threshold=INFO

三、添加Log4jMyAppender类

//log4j配置文件
public class Log4jMyAppender extends DailyRollingFileAppender {

    @Override
    public boolean isAsSevereAsThreshold(Priority priority) {
        //只判断是否相等,而不判断优先级
        return this.getThreshold().equals(priority);
    }

}

四、 在使用到的类中声明log以及输出log信息。

import org.apache.log4j.Logger;
@Service
public class AngelServiceImpl implements AngelService{
    private static Logger log = Logger.getLogger(AngelServiceImpl.class);
}

五、配置显示mybatis的sql语句

  1. 需要在application.yml中配置mybatis输出日志:
mybatis:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

org.apache.ibatis.logging.stdout.StdOutImpl:这个是可以sql、参数、查询结果的
org.apache.ibatis.logging.log4j.Log4jImpl:这个不打印查询结果
这个就和在mybatis.xml中配置一样:

<configuration>
    <settings>
        <setting name="logImpl" value="STDOUT_LOGGING"/>
    </settings>
</configuration>
  1. 在log4j.properties文件中配置如下
#打印sql部分
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Connection = DEBUG
log4j.logger.java.sql.Statement = DEBUG
log4j.logger.java.sql.PreparedStatement = DEBUG
log4j.logger.java.sql.ResultSet = DEBUG

#配置logger扫描的包路径  这样才会打印sql
log4j.logger.cn.com.bluemoon.bd.report.service.dao=DEBUG

参考文章:https://www.cnblogs.com/30go/p/8443435.html
参考文章:https://blog.csdn.net/qq_15006743/article/details/82464914

上一篇 下一篇

猜你喜欢

热点阅读