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

日志系统

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

分享给朋友:

“日志系统” 的相关文章

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

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

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

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

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

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、水仙花:百位数的立方+十位数的地方+个位数的立方等于这个数本身。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练习:百钱百鸡利用Java进行实现

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

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

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

Java练习:将数组中的元素首尾调换

数组课堂练习:将数组中的元素首尾调换 public static void main(String[] args) { // 数组课堂练习:将数组中的元素首尾调换 int[] a = { ...

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

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

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

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

发表评论

访客

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