最近需要改造以前的SpringMVC項(xiàng)目家坎,將改為SpringBoot項(xiàng)目理卑,以前的項(xiàng)目打印日志是使用log4j的宦言,但SpringBoot用的默認(rèn)日志框架是Logback堤舒。
一、添加依賴
修改pom.xml文件誉碴,過濾掉自帶的spring-boot-starter-logging宦棺,然后添加spring-boot-starter-log4j依賴包。不過濾掉啟動(dòng)的時(shí)候會(huì)報(bào)錯(cuò)
<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四種輸出格式。
# 設(shè)定logger的root
log4j.rootLogger=info,error,info,warn,stdout
##############打印到平臺(tái)的日志##################
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) {
//只判斷是否相等呐芥,而不判斷優(yōu)先級(jí)
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語句
- 需要在application.yml中配置mybatis輸出日志:
mybatis:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
org.apache.ibatis.logging.stdout.StdOutImpl
:這個(gè)是可以sql、參數(shù)闻伶、查詢結(jié)果的
org.apache.ibatis.logging.log4j.Log4jImpl
:這個(gè)不打印查詢結(jié)果
這個(gè)就和在mybatis.xml中配置一樣:
<configuration>
<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
</configuration>
- 在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掃描的包路徑 這樣才會(huì)打印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