log

项目中日志配置

Posted by Clear Blog on December 8, 2018

spring整合mybatis日志,打印sql。 因为spring5中自己实现了jul, 而mybatis中会按照如下顺序获得Log对象的Constructor,然后反射生成Log实例。 所以如果项目中没有引用slf4j而使用的是log4j的时候,在spring5中会导致mybatis中的log失效, 此时会默认的使用useCommonsLogging()来作为mybatis中日志打印。

另外官方给了用java配置的方式来配置mybatis中使用哪个日志方案。 可以自己实现org.apache.ibatis.logging.Log,然后设置日志级别以及日志实现类, 也可以直接使用官方给的如下几个静态方法。

1
2
3
4
5
6
org.apache.ibatis.logging.LogFactory.useSlf4jLogging();
org.apache.ibatis.logging.LogFactory.useLog4JLogging();
org.apache.ibatis.logging.LogFactory.useLog4J2Logging();
org.apache.ibatis.logging.LogFactory.useJdkLogging();
org.apache.ibatis.logging.LogFactory.useCommonsLogging();
org.apache.ibatis.logging.LogFactory.useStdOutLogging();
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
static {
    tryImplementation(new Runnable() {
      @Override
      public void run() {
        useSlf4jLogging();
      }
    });
    tryImplementation(new Runnable() {
      @Override
      public void run() {
        useCommonsLogging();
      }
    });
    tryImplementation(new Runnable() {
      @Override
      public void run() {
        useLog4J2Logging();
      }
    });
    tryImplementation(new Runnable() {
      @Override
      public void run() {
        useLog4JLogging();
      }
    });
    tryImplementation(new Runnable() {
      @Override
      public void run() {
        useJdkLogging();
      }
    });
    tryImplementation(new Runnable() {
      @Override
      public void run() {
        useNoLogging();
      }
    });
  }

附上最简单的日志配置文件

  1. log4j2 ````xml <?xml version=”1.0” encoding=”UTF-8”?>
1
2
3
4
5
6
7
8
9
10
11
2. log4j

````properties
log4j.rootLogger=info, console

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{HH:mm:ss,SSS} [%c] - %m%n

log4j.logger.com.clear.mapper=debug
  1. logback
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
        <!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,,,, -->
        <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
                <encoder>
                        <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
                </encoder>
        </appender>
        <appender name="INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <file>${sys:pafa.log.home}/pafa_info.log</file>
                <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                        <fileNamePattern>${sys:pafa.log.home}/pafa_info.log.%d{yyyy-MM-dd}</fileNamePattern>
                        <maxFileSize>100MB</maxFileSize>
                        <maxHistory>7</maxHistory>
                        <totalSizeCap>10GB</totalSizeCap>
                </rollingPolicy>
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                        <level>INFO</level>
                        <onMatch>ACCEPT</onMatch>
                        <onMismatch>DENY</onMismatch>
                </filter>
                <encoder>
                        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
                </encoder>
        </appender>

        <appender name="WARN"
                class="ch.qos.logback.core.rolling.RollingFileAppender">
                <file>${sys:pafa.log.home}/pafa_warn.log</file>
                <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                        <fileNamePattern>${sys:pafa.log.home}/pafa_warn.log.%d{yyyy-MM-dd}</fileNamePattern>
                        <maxFileSize>100MB</maxFileSize>
                        <maxHistory>7</maxHistory>
                        <totalSizeCap>10GB</totalSizeCap>
                </rollingPolicy>
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                        <level>WARN</level>
                        <onMatch>ACCEPT</onMatch>
                        <onMismatch>DENY</onMismatch>
                </filter>
                <encoder>
                        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
                </encoder>
        </appender>

        <appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
                <file>${sys:pafa.log.home}/pafa_error.log</file>
                <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                        <fileNamePattern>${sys:pafa.log.home}/pafa_error.log.%d{yyyy-MM-dd}</fileNamePattern>
                        <maxFileSize>100MB</maxFileSize>
                        <maxHistory>7</maxHistory>
                        <totalSizeCap>10GB</totalSizeCap>
                </rollingPolicy>
                <filter class="ch.qos.logback.classic.filter.LevelFilter">
                        <level>ERROR</level>
                        <onMatch>ACCEPT</onMatch>
                        <onMismatch>DENY</onMismatch>
                </filter>
                <encoder>
                        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
                </encoder>
        </appender>

        <root level="STDOUT">
                <appender-ref ref="STDOUT" />
                <appender-ref ref="INFO" />
                <appender-ref ref="WARN" />
                <appender-ref ref="ERROR" />
        </root>

</configuration>
  1. Log4j2 ````xml <?xml version=”1.0” encoding=”UTF-8”?>

````