美文网首页Web项目
SpringBoot 使用log4j打印日志

SpringBoot 使用log4j打印日志

作者: weisen | 来源:发表于2018-11-27 15:19 被阅读0次

    最近需要改造以前的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

    相关文章

      网友评论

        本文标题:SpringBoot 使用log4j打印日志

        本文链接:https://www.haomeiwen.com/subject/zcvgqqtx.html