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

日志系统

刘广法2022年05月05日 10:31:42Java教程9800
日志系统-第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/java/184.html

分享给朋友:

“日志系统” 的相关文章

使用eclipse进行文件的导入和导出

使用eclipse进行文件的导入和导出

该说不说,学会这个项目可以省很多的事情,刘广法可以用这个方法借鉴同学的项目,可以进行参考、借鉴、以及抄作业。一、使用eclipse进行项目的导出:1、使用eclipse进行项目的导出第一步:找到所在的项目工作空间,如果你知道的话,可以直接打开文件进行打包发送给你的好友,如果想要知道项目工作空间如何修...

eclipse 自动提示功能的实现

eclipse 自动提示功能的实现

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

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

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

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

eclipse 如何更换JDK版本 替换自带的JDK版本

eclipse 如何更换JDK版本 替换自带的JDK版本

设置jdk,用安装的JDK替换eclipse自带的JDK(详细步骤)1、Window-->Presferences2、进入后,搜索“java”,找到“Installed JRES”3、删除自带的JDK:选中自带的jdk,然后选择remove。4、添加自己安装的JDK:选中右边的Add,选择St...

Java练习:从控制台输入一个年份,统计输入的年份到现在一共多少天?

从控制台输入一个年份,统计输入的年份到现在一共多少天?注意事项:1、平年365天,闰年十366天。2月份平年28天,2月份闰年29年。2、今年2022年3月14日3、闰年判断:能够被四百整数;能被4整数但不能被100整数public static void main(S...

用Java实现打印各种图形总结篇(矩形、平行四边形、三角形、菱形)

1、用Java实现打印矩形(长方形、正方形): public static void main(String[] args) { for (int y = 0; y < ...

Java教程 第六节:数组

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

Java练习:控制台输入十个成绩,编程对这些成绩取平均值,并判断出成绩最大值和成绩最小值

有控制台输入十个成绩,编程对这些成绩取平均值,并判断出成绩最大值和成绩最小值 public static void main(String[] args) { // 有控制台输入十个成绩,编程对这些成绩取平均值,并判断出成绩最大值和成...

Java教程第七节:选择排序法和和冒泡排序法

选择法排序:分为若干轮比较,每一轮找出一个最大值。刘广法整理思路:假设有数组{ 1, 2, 3, 5, 98, 24, 6, 456, 14 },假设第一个数字最大,然后从第二个开始依次和第一个比,如...

Java练习:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数

Java课后作业:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数问题1:判断两个数组中重叠的元素?问题2:重叠的元素都重叠了几次,进行排序输出?本题关键:去重(验证之前是否验证过此数)、排序,(冒泡排序法和选择排序法)、关键字break 和continue 的使用 //&n...

Java教程 第八节:方法

定义方法:返回值类型 函数名称(函数列表){       // 函数体,可以执行代码,可以是0行或者多行。}我们常见的 main 方法就是一个在Java中最常见的方法:public static viod main(String []arg...

Java练习:递归的实操

Java练习:递归的实操

Java学习:递归的实操递归就是直接或者间接调用滋生。需要注意的就是,一定要有一个判断条件让这个死循环结束。Java学习递归实操训练一:利用递归算出10的阶乘:此方法是常规方法:<主要用作和下面用递归的对比> public static void main(...

发表评论

访客

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