mybatis-plus可以在控制臺打印斋扰,卻無法通過logback輸出
- 問題描述
通過官網(wǎng)配置,將mybatis-plus引入spring boot項(xiàng)目中莲祸,但是日志只能在控制臺中輸出,卻無法在logback的日志文件中輸出
// 具體參考網(wǎng)址
// https://mp.baomidou.com/guide/faq.html#%E5%90%AF%E5%8A%A8-mybatis-%E6%9C%AC%E8%BA%AB%E7%9A%84-log-%E6%97%A5%E5%BF%97
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
- 解決過程
1凳干、點(diǎn)擊進(jìn)入StdOutImpl方法中查看,此方法是通過System.out.println打印的昆稿,logback在非配置情況下無法輸出此內(nèi)容纺座。
2、System.out.println在logback打印文件中輸出溉潭,我查到三種方法
System.setOut(new PrintStream(new File("日志路徑")));
System.out.println();
<dependency>
<groupId>uk.org.lidalia</groupId>
<artifactId>sysout-over-slf4j</artifactId>
<version>1.0.2</version>
</dependency>
web.xml 文件中添加
<listener>
<listener-class>uk.org.lidalia.sysoutslf4j.context.SysOutOverSLF4JServletContextListener</listener-class>
</listener>
- 方法三:spring-boot項(xiàng)目使用nohup命令啟動未指定日志文件輸出净响,所有日志均會輸出到nohup.out中少欺。可以定時寫一個shell腳本馋贤,按日期切割nohup.out中內(nèi)容赞别,棄用logback輸出的日志文件
this_path=$(cd `dirname $0`;pwd)
cd $this_path
echo $this_path
current_date=`date -d "-1 day" "+%Y%m%d"`
echo $current_date
// 分割出指定字符大小,到新文件中
split -b +100m -d -a 4 /home/.../nohup.out /home/.../log/log_${current_date}_
// 清空nohup.out配乓,等待下一次分割
cat /dev/null > nohup.out
以上3種方法都不太適用于我當(dāng)前的需求仿滔,需要換個角度解決這個問題,比如犹芹,放棄使用StdOutImpl來輸出日志
- 解決方案
放棄使用StdOutImpl輸出日志崎页,去掉log-impl: org.apache.ibatis.logging.stdout.StdOutImpl 配置。在application.yml中使用常規(guī)logback-spring配置腰埂。
logging:
level:
com.XXX.mapper: debug
就可以正常輸出sql語句了飒焦。