springboot2.0+log4jdbc将sql语句完整写入日志文件并分开保存

Easter79
• 阅读 871

首先,引入pom依赖:

org.springframework.boot spring-boot-starter-log4j2 com.lmax disruptor 3.3.6 org.bgee.log4jdbc-log4j2 log4jdbc-log4j2-jdbc4.1 1.16

接着修改application.yml配置文件(具体视情况而定)

springboot2.0+log4jdbc将sql语句完整写入日志文件并分开保存

driver-class-name: net.sf.log4jdbc.sql.jdbcapi.DriverSpy

url: jdbc:log4jdbc:mysql://127.0.0.1:3306/xxxx?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true

指定log4j2的配置文件路径

springboot2.0+log4jdbc将sql语句完整写入日志文件并分开保存

log4j2-test.xml的内容如下

<!-- 日志文件目录、压缩文件目录、日志格式配置 -->
<properties>
    <Property name="fileName">c:/logs/xxxx/api</Property>
    <Property name="fileGz">c:/logs/xxxx/api/7z</Property>
    <Property name="LOG\_PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} \[%thread\] %-5level %logger{36} - %msg%n</Property>
</properties>

<Appenders>
    <!-- 输出控制台日志的配置 -->
    <Console name="console" target="SYSTEM\_OUT">
        <!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)-->
        <ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY"/>
        <!-- 输出日志的格式 -->
        <PatternLayout pattern="${LOG\_PATTERN}"/>
    </Console>

    <!-- 打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档 -->
    <RollingRandomAccessFile name="infoFile" fileName="${fileName}/web-info.log" immediateFlush="false" filePattern="${fileGz}/$${date:yyyy-MM}/%d{yyyy-MM-dd}-%i.web-info.gz">
        <PatternLayout pattern="${LOG\_PATTERN}"/>
        <Policies>
            <SizeBasedTriggeringPolicy size="20 MB"/>
        </Policies>

        <Filters>
            <!-- 只记录info和warn级别信息 -->
            <ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/>
            <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
        </Filters>

        <!-- 指定每天的最大压缩包个数,默认7个,超过了会覆盖之前的 -->
        <DefaultRolloverStrategy max="50"/>
    </RollingRandomAccessFile>

    <!-- 存储所有error信息 -->
    <RollingRandomAccessFile name="errorFile" fileName="${fileName}/web-error.log" immediateFlush="false" filePattern="${fileGz}/$${date:yyyy-MM}/%d{yyyy-MM-dd}-%i.web-error.gz">
        <PatternLayout pattern="${LOG\_PATTERN}"/>

        <Policies>
            <SizeBasedTriggeringPolicy size="50 MB"/>
        </Policies>

        <Filters>
            <!-- 只记录error级别信息 -->
            <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
        </Filters>

        <!-- 指定每天的最大压缩包个数,默认7个,超过了会覆盖之前的 -->
        <DefaultRolloverStrategy max="50"/>
    </RollingRandomAccessFile>

    <File name="log4jdbc\_delete" fileName="c:/logs/xxxx/api/log4jdbc\_delete.log">
        <MarkerFilter marker="LOG4JDBC\_DELETE" onMatch="ACCEPT" onMismatch="DENY"/>
        <PatternLayout pattern="%d %-5p %t (%c:%L) - %m%n"/>
    </File>
    <File name="log4jdbc\_insert" fileName="c:/logs/xxxx/api/log4jdbc\_insert.log">
        <MarkerFilter marker="LOG4JDBC\_INSERT" onMatch="ACCEPT" onMismatch="DENY"/>
        <PatternLayout pattern="%d %-5p %t (%c:%L) - %m%n"/>
    </File>
    <File name="log4jdbc\_update" fileName="c:/logs/xxxx/api/log4jdbc\_update.log">
        <MarkerFilter marker="LOG4JDBC\_UPDATE" onMatch="ACCEPT" onMismatch="DENY"/>
        <PatternLayout pattern="%d %-5p %t (%c:%L) - %m%n"/>
    </File>
    <File name="log4jdbc\_select" fileName="c:/logs/xxxx/api/log4jdbc\_select.log">
        <MarkerFilter marker="LOG4JDBC\_SELECT" onMatch="ACCEPT" onMismatch="DENY"/>
        <PatternLayout pattern="%d %-5p %t (%c:%L) - %m%n"/>
    </File>
    
</Appenders>

<Loggers>
    <logger name="org.springframework.aop.framework.CglibAopProxy" level="ERROR" additivity="false"/>
    <logger name="springfox.documentation" level="ERROR" additivity="false"/>
    <logger name="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping" level="ERROR" additivity="false"/>
    <logger name="org.springframework.core.env.PropertySourcesPropertyResolver" level="ERROR" additivity="false"/>
    <logger name="org.springframework.web.servlet.DispatcherServlet" level="ERROR" additivity="false"/>
    <logger name="io.undertow.servlet" level="ERROR" additivity="false"/>
    <logger name="org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod" level="TRACE"/>

    <logger name="jdbc.sqlonly" level="INFO" additivity="false"/>
    <logger name="jdbc.resultset" level="INFO" additivity="false"/>
    <logger name="jdbc.connection" level="INFO" additivity="false"/>
    <logger name="jdbc.audit" level="INFO" additivity="false"/>
    <logger name="jdbc.sqltiming" level="INFO" additivity="false">
        <appender-ref ref="console"/>
    </logger>

    <!--项目日志等级-->
    <logger name="com.junko" level="DEBUG"/>

    <logger name="log4jdbc.debug" level="INFO" additivity="false">
        <appender-ref ref="console"/>
    </logger>

    <!-- 同步异步混合的方式进行写日志 -->
    <AsyncLogger name="AsyncLogger" level="INFO" includeLocation="true">
        <appender-ref ref="console" />
        <appender-ref ref="infoFile" />
        <appender-ref ref="errorFile" />
    </AsyncLogger>
    <asyncRoot level="INFO" includeLocation="true">
        <appender-ref ref="console" />
        <appender-ref ref="infoFile" />
        <appender-ref ref="errorFile" />
    </asyncRoot>

    <logger name="log4jdbc.log4j2" level="info" additivity="false">
        <MarkerFilter marker="LOG4JDBC\_OTHER" onMatch="DENY" onMismatch="NEUTRAL"/>
        <appender-ref ref="log4jdbc\_insert"/>
        <appender-ref ref="log4jdbc\_delete"/>
        <appender-ref ref="log4jdbc\_update"/>
        <appender-ref ref="log4jdbc\_select"/>
        <appender-ref ref="console"/>
    </logger>
</Loggers>

项目运行后,打开目录查看:

springboot2.0+log4jdbc将sql语句完整写入日志文件并分开保存

增删改查的执行语句已分开保存,再查看log4jdbc_select.log文件:

springboot2.0+log4jdbc将sql语句完整写入日志文件并分开保存

可以看到,sql语句里的 ? 占位符已经是实际传入的参数了。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用
1\.activemq  首先引入依赖  pom.xml文件<dependency<groupIdorg.springframework.boot</groupId<artifactIdspringbootstarteractivemq</artifactId</depe
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Easter79 Easter79
3年前
SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用
1\.activemq  首先引入依赖  pom.xml文件<dependency<groupIdorg.springframework.boot</groupId<artifactIdspringbootstarteractivemq</artifactId</depe
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Easter79
Easter79
Lv1
今生可爱与温柔,每一样都不能少。
文章
2.8k
粉丝
6
获赞
1.2k