当前位置:首页 > 学习笔记 > Java教程 > 日志系统

日志系统

刘广法2022年05月05日 10:31:42Java教程3500
日志系统-第1张图片-刘广法IT博客

日志插件:

主流的实现:log4j2,logback,commons-logging,jdk-log

主流的接口:slf4j,spring-jcl


使用spring-jcl + logback 测试


日志记录一般有5个级别:

  1. trace : 路由级别,最低级别。

  2. debug:调试级别,记录调试信息。

  3. info:信息级别,记录一些普通信息。

  4. error:记录错误或异常信息。

  5. fatal:严重系统异常。最高级别。


日志系统,配置文件实例:

首先,需要导入依赖到pom.xml 文件中

<!-- 日志相关包 -->
<dependency>
	<groupId>ch.qos.logback</groupId>
	<artifactId>logback-core</artifactId>
	<version>1.2.11</version>
</dependency>
<dependency>
	<groupId>ch.qos.logback</groupId>
	<artifactId>logback-classic</artifactId>
	<version>1.2.11</version>
</dependency>

在mybatis.xml 中的配置:

<!-- 输出查询语句及相关日志,logImpl属性用于指定MyBatis所用日志的具体实现,未指定时将自动检测。
        检测顺序依次为:SLF4J | LOG4J | LOG4J2 | JDK_LOGGING | COMMONS_LOGGING | STDOUT_LOGGING | NO_LOGGING。
        STDOUT_LOGGING表示输出到控制台,在整合了springmvc时,推荐选择COMMONS_LOGGING,表示使用spring-jcl进行日志记录,
        spring对此部分进行了重写,但包名依旧沿用org.apache.commons.logging,可自动匹配日志实现,包括slf4j。 -->
		<setting name="logImpl" value="COMMONS_LOGGING" />
		
		<!-- logPrefix属性用于指定MyBatis增加到日志名称的前缀,配置此属性,是方便于其它日志记录插件使用。
		value值应以点结尾,以与真正的日志名称分隔。若不指定此属性,则默认日志名称的前缀应为dao接口所在包。
		如:dao接口为com.situ.dao.CategoryDAO,则日志名称为:com.situ.dao.CategoryDAO,若指定了以下前缀,
		则日志名称变为mybatis.dao.com.situ.dao.CategoryDAO,此时日志插件再使用com.situ.dao作为判定输出的前缀,已经无效。
		如果项目中的dao接口分散在不同的包里,则此属性就可派上用场,添加此配置后,即所有日志名称均以此配置值为前缀,
		那么日志实现就可指定此虚拟的包名mybatis.dao了。注意:一旦指定使用此配置指定前缀,则日志记录插件使用默认的原始包名做前缀将失败 -->
		<setting name="logPrefix" value="mybatis.dao." />


类的根路径下的logback.xml配置:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

	<!-- 标准控制台输出 -->
	<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
		<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
			<Pattern>%d{HH:mm:ss.SSS} %-5level %logger{80} - %msg%n</Pattern>
		</encoder>
	</appender>

	<!-- 滚动文件输出。配置输出文件路径时,注意windows系统以类似"d:/"开始 -->
	<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
		<file>d:/logs/students2022/logFile.log</file>
		<!-- 滚动策略 -->
		<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
			<fileNamePattern>d:/logs/students2022/logFile-%d{yyyy-MM-dd}.%i.zip</fileNamePattern>
			<maxHistory>30</maxHistory>
			<maxFileSize>5MB</maxFileSize>
			<totalSizeCap>100MB</totalSizeCap>
		</rollingPolicy>
		<!-- 输出格式 -->
		<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
			<Pattern>%d{HH:mm:ss.SSS} %-5level %logger{80} - %msg%n</Pattern>
		</encoder>
	</appender>
	
	<!-- 异步文件日志记录器 -->
	<appender name="AsyncFILE" class="ch.qos.logback.classic.AsyncAppender">
		<appender-ref ref="FILE" />
	</appender>

	<!-- 配置日志的输出方式 -->
	<!-- 开发模式,此处选择了控制台输出。对于生产模式,一般是将日志记录到文件 -->
	<root>
		<!-- 输出日志的级别 -->
		<level value="INFO" />
		<!-- 输出到控制台 -->
		<appender-ref ref="STDOUT" />
		<appender-ref ref="FILE" />
	</root>
	
	<!-- 输出mybatis日志 -->
	<logger name="mybatis.dao" level="DEBUG" />
	
</configuration>


来源:刘广法博客,请注意转载出处,网站地址为:https://liuguangfa.com/

扫描二维码推送至手机访问。

版权声明:本文由刘广法博客发布,如需转载请注明出处。

本文链接:https://liuguangfa.com/java/184.html

分享给朋友:

“日志系统” 的相关文章

java教程 第三节:基本数据类型和运算符

一、算术运算符+:加-:减*:乘/:除%:取余例如:a+b、a-b、a*b、a/b、a%b当两个操作数都为整数时,结果必定为整数。当其中一个操作数为小数时,则为小数除。去余数,通常是一对正正整取余数,事实上,对小数和负数一样取余数。小数(浮点数)在计算机中不是精确存在的,并不是精确存在的。二、比较运...

Java教程 第四节:流程控制语句总结

流程控制语句:一、顺序结构顺序结构:按照写代码的顺序 一次执行二、分支结构1、if语句if(条件){     语句块 }2、if...else...语句if(条件){     语句块 }else{  ...

java学习:Java流程控制语句的相关测试题

第一题:将所有包含3的三位数整数相加求和。103 131 133 301类似。public static void main(String[] args) { int n = 100;// 从n开始三位数...

eclipse删除工作空间的详细步骤(图解)

eclipse删除工作空间的详细步骤(图解)

上一次我修改添加eclipce的工作空间,但只我的eclipce上有两个工作空间,今天我想删除一个第一步: Window > Preferences > General > startup and shutdown -->workspace这就是删除eclipse的...

eclipse 自动提示功能的实现

eclipse 自动提示功能的实现

之前用的版本都是有提示的,最近安装的最新版没有提示,今天就设置让自动提示出来第一步:windows”->"preferences",弹出preferences设置窗口。第二步:在preferences中找到Java,依次展开列表"Editor"->...

eclipse的快捷键功能

eclipse的快捷键功能

有一些快捷键是可以修改的,具体修改过程如图下:修改快捷的详细步骤:1、使用快捷键调出快捷键列表进行查看:快捷键列表调用:shift + ctrl + L2、window->preferences->general->keys(或直接搜索keys)快捷键列表:shuft + ctrl...

eclipse 修改默认的工作空间以及修改个人工作空间的编码

eclipse 修改默认的工作空间以及修改个人工作空间的编码

一、修改工作空间workspaceFile-->Awitch Workspace-->Other,就打开下面的图,然后选择我标起来的就可以新建工作空间了。二、设置工作空间workspace的编码为UTF-8设置完你所用的工作空间也就是上一步后,需要修改工作空间的编码为UTF-8步骤如下:...

Java练习:找出三位数中所有的水仙花的值

找到三位数中所有为水仙花的值1、水仙花:百位数的立方+十位数的地方+个位数的立方等于这个数本身。2、三位数中。具体的步骤:public static void main(String[] args) { int i =&nbs...

Java练习:百钱百鸡利用Java进行实现

今有100块钱,需要购买100只鸡,已知鸡的价格是:公鸡5元,母鸡3元,小鸡三只元,问:需要购买多少只公鸡、母鸡、小鸡?Java实现百鸡百钱的方法一: public static void main(String[] args) { for&n...

Java练习:打印出所有3位数的素数

课堂练习:打印出所有3位数的素数。素数:只能被1和其本身整除的数 public static void main(String[] args) { // 打印三位数的素数,素数只能被1和本身整数的数。 for (int...

Java学习 第五节:break和continue关键字

break和continue关键字break:表示中断,退出。退出当前一层循环。一旦break,后面的语句将不会得到执行。continue:中断本次循环,直接进行下一次的循环。continue后面的语句将不会得到执行。...

Java教程 第六节:数组

数组数组:简单来说,就是一组相同数据类型的数。float[] score = new float[6];索引或者下标:必须是整数,不能为负。最大下标等于数组长度-1。float[0],就是float类型数据score的第一个项。数组的下标结合循环,可以简化对批...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。