6、日志

6.1、日志工厂

如果一个数据库操作,出现了异常,我们需要排错。日志就是最好的助手!

曾经:sout、debug

现在:日志工厂

  • SLF4J
  • LOG4J【掌握】
  • LOG4J2
  • JDK_LOGGING
  • COMMONS_LOGGING
  • STDOUT_LOGGING【掌握】
  • NO_LOGGING

在Mybatis中具体使用那个日志实现,在设置中设定!

STDOUT_LOGGING标准日志输出

在mybatis核心配置文件中,配置我们的日志!

<settings>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>

6.2、Log4j

什么事log4j

  • Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件
  • 我们也可以控制每一条日志的输出格式
  • 通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。
  • 通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

1.先导入log4j的包

    <dependencies>
<!-- https://mvnrepository.com/artifact/log4j/log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
</dependencies>

2.log4j.properties

log4j.rootLogger=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=5
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n

3.配置log4j为日志实现

    <settings>
<setting name="logImpl" value="LOG4J"/>
</settings>

4.log4j的使用!直接测试运行刚才的查询

DEBUG [main] (LogFactory.java:105) - Logging initialized using 'class org.apache.ibatis.logging.log4j.Log4jImpl' adapter.
DEBUG [main] (LogFactory.java:105) - Logging initialized using 'class org.apache.ibatis.logging.log4j.Log4jImpl' adapter.
DEBUG [main] (PooledDataSource.java:353) - PooledDataSource forcefully closed/removed all connections.
DEBUG [main] (PooledDataSource.java:353) - PooledDataSource forcefully closed/removed all connections.
DEBUG [main] (PooledDataSource.java:353) - PooledDataSource forcefully closed/removed all connections.
DEBUG [main] (PooledDataSource.java:353) - PooledDataSource forcefully closed/removed all connections.
DEBUG [main] (JdbcTransaction.java:136) - Opening JDBC Connection
Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.
DEBUG [main] (PooledDataSource.java:424) - Created connection 2049051802.
DEBUG [main] (JdbcTransaction.java:100) - Setting autocommit to false on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@7a220c9a]
DEBUG [main] (BaseJdbcLogger.java:143) - ==> Preparing: /*定义sql*/ select * from mybatis.user where id = ?;
DEBUG [main] (BaseJdbcLogger.java:143) - ==> Parameters: 1(Integer)
DEBUG [main] (BaseJdbcLogger.java:143) - <== Total: 1
User{id=1, name='狂神', password='123456'}
DEBUG [main] (JdbcTransaction.java:122) - Resetting autocommit to true on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@7a220c9a]
DEBUG [main] (JdbcTransaction.java:90) - Closing JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@7a220c9a]
DEBUG [main] (PooledDataSource.java:381) - Returned connection 2049051802 to pool. Disconnected from the target VM, address: '127.0.0.1:58296', transport: 'socket' Process finished with exit code 0

简单使用

  1. 在要使用Log4j 的类中,导入org.apache.log4j.Logger;

  2. 日志对象,加载参数为当前类的class

     static Logger logger = Logger.getLogger(UserDaoTest.class);
  3. 日志级别

    logger.info("info:进入了testLog4j方法");
    logger.debug("debug:进入了testLog4j");
    logger.error("error:进入了testLog4j");

最新文章

  1. iOS--雪花掉落特效
  2. Android 对Map按key和value分别排序
  3. SAP_20140304
  4. 凸包模板 POJ1873
  5. XPath操作XML文档
  6. TOGAF架构能力框架之架构能力建设和架构治理
  7. jquery_api(事件一)
  8. WINDOWS下搭建SVN服务器端的步骤分享(Subversion)
  9. SVN和Git的一些用法总结
  10. 使用HttpClient进行Get方式通信
  11. 【1414软工助教】团队作业8——第二次项目冲刺(Beta阶段) 得分榜
  12. 几个常用内核函数(《Windows内核情景分析》)
  13. mysql 开发进阶篇系列 20 MySQL Server(innodb_lock_wait_timeout,innodb_support_xa,innodb _log_*)
  14. SpringBoot无废话入门01:最简SpringBoot应用
  15. qrcode生成二维码
  16. Vue的新启之笔
  17. Mongodb集群节点故障恢复场景分析(转)
  18. javascript:this指向
  19. .net页面生命周期【转】
  20. 关于在VWmare下安装Redhat

热门文章

  1. 【并行计算-CUDA开发】 NVIDIA Jetson TX1
  2. HDU6582 Path【优先队列优化最短路 + dinic最大流 == 最小割】
  3. 第一周--------带标签的 continue
  4. js中函数总结(1)
  5. Spark Scala当中reduceByKey(_+_) reduceByKey((x,y) =&gt; x+y)的用法
  6. Git初始化配置以及配置github
  7. C/C++快读(快速读入)有多——安全AC
  8. Thinking In Java 4th Chap2 一切都是对象
  9. OpsManager管理MongoDB
  10. 【hash表】门票