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

日志系统

刘广法2022年05月05日 10:31:42Java教程4730
日志系统-第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

分享给朋友:

“日志系统” 的相关文章

JDK的安装卸载以及环境配置

JDK的安装卸载以及环境配置

一、安装JDK首先应该先下载JDK,下面两个网站都是可以下载:下载地址:https://www.oracle.com/java/technologies/javase-downloads.htmlopenJDK 下载:http://jdk.java.net/下载的的就是下面这样的图标,版本号可能不一...

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

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

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

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 如何更换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、水仙花:百位数的立方+十位数的地方+个位数的立方等于这个数本身。2、三位数中。具体的步骤:public static void main(String[] args) { int i =&nbs...

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

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

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

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

Java教程 第八节:方法

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

发表评论

访客

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