log4jdbc 与 logback 集合打印日志过多的解决

在项目中使用了log4jdbc,能够很方便的把sql的参数也打印出来,便于问题调试。好比原始sql: select * from t_order where order_id = ? ; 通过log4jdbc的处理后就变成了 select * from t_order where order_id = 123。 可是通过这个处理之后,默认会打印sql相关的不少信息,好比链接、执行时间、参数绑定、结果等信息, 会使日志打印迅速膨胀,我这里服务调用比较频繁,有两个定时任务在调用服务,日志天天在50G左右。因而在 log4jdbc.properties 进行了相关配置,可是没有什么效果。 后来在logback.xml 增长了以下配置:sql

    <logger name="jdbc.sqlonly" level="ERROR">
        <appender-ref ref="rollingFile"/>
    </logger>
    <logger name="jdbc.audit" level="ERROR">
        <appender-ref ref="rollingFile"/>
    </logger>
    <logger name="jdbc.resultset" level="ERROR">
        <appender-ref ref="rollingFile"/>
    </logger>
    <logger name="jdbc.connection" level="ERROR">
        <appender-ref ref="rollingFile"/>
    </logger>

将jdbc.only, jdbc.audit, jdbc.resultset, jdbc.connection 的打印级别设置为ERROR, 减小了这部分的打印,你们可根据本身的需求进行配置级别。通过优化后天天在1G之内。apache

附log4jdbc.properties的配置以下:app

log4j.logger.jdbc.sqlonly=DEBUG,console
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %m%n%n
log4j.logger.jdbc.sqltiming=DEBUG,console
log4j.logger.jdbc.connection=DEBUG,console

曾尝试在以上文件中修改DEBUG为ERROR、OFF 都无效。 猜测是由于logback接管了log的输出配置,因此必须在logback中进行配置。 后面有时间再研究下是个什么缘由。优化

相关文章
相关标签/搜索