1.日志概述
日志
用来记录程序运行过程中的信息,并可以进行永久存储。
日志技术应该具备哪些特点和优势
1.可以将系统执行的信息,方便的记录到指定的位置(控制台、文件中、数据库中)
2.可以随时以开关的形式控制是日志的记录和取消,无需进入到源代码中去进行修改;

2.日志技术体系、Logback概述
日志体系结构

Logback日志框架
官网:https://logback.qos.ch/index.html
http://www.slf4j.org/
Logback日志框架分为以下模块
logback-core: 该模块为其他两个模块提供基础代码。(必须有)
logback-classic: 完整实现了slf4j API的模块。(必须有)
logback-access: 与 Tomcat 和 Jetty 等 Servlet 容器集成,以提供 HTTP 访问日志功能。
想使用Logback日志框架,至少需要在项目中整合如下三个模块:
slf4j-api: 日志接口
logback-core: 基础模块
logback-classic: 功能模块,它完整实现了slf4j API
3.Logback快速入门
实现步骤
1.导入Logback框架到项目中去。在模块下新建文件夹lib,导入Logback的jar包到该文件夹下;
2.将存放jar文件的lib文件夹添加到项目依赖库中去;
3.将Logback的核心配置文件logback.xml直接拷贝到src目录下(必须是src下);
4.创建Logback框架提供的Logger日志对象,后续调用其方法记录系统的日志信息;
public static final Logger LOGGER = LoggerFactory.getLogger(“类名");
官网下载:https://logback.qos.ch/index.html


Logback配置
对Logback日志框架的控制,都是通过核心配置文件logback.xml来实现的。
Logback日志输出位置、格式设置
通过logback.xml 中的标签可以设置输出位置,通常可以设置2个日志输出位置:一个是控制台、一个是系统文件中。
输出到控制台的配置标志
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
输出到系统文件的配置标志
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
Logback日志级别设置
<!--
level:用来设置打印级别,大小写无关:TRACE < DEBUG < INFO < WARN < ERROR, ALL 和 OFF, 默认debug
<root>可以包含零个或多个<appender-ref>元素,标识这个输出位置将会被本日志级别控制。
-->
<root level="ALL">
<!--设置控制台输出-->
<appender-ref ref="CONSOLE"/>
<!--设置在文件中输出-->
<appender-ref ref="FILE" />
</root>
示例配置
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<!--
CONSOLE :表示当前的日志信息是可以输出到控制台的。
-->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<!--输出流对象 默认 System.out 改为 System.err-->
<target>System.out</target>
<encoder>
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度
%msg:日志消息,%n是换行符 %c:类名-->
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5level] %c [%thread] : %msg%n</pattern>
</encoder>
</appender>
<!-- File是输出的方向通向文件的 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<encoder>
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
<charset>utf-8</charset>
</encoder>
<!--日志输出路径-->
<file>E:/Log/data.log</file>
<!--指定日志文件拆分和压缩规则-->
<rollingPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<!--通过指定压缩文件名称,来确定分割文件方式-->
<fileNamePattern>E:/Log/data-%d{yyyy-MMdd}.log%i.gz</fileNamePattern>
<!--文件拆分大小-->
<maxFileSize>1MB</maxFileSize>
</rollingPolicy>
</appender>
<!--
level:用来设置打印级别,大小写无关:TRACE < DEBUG < INFO < WARN < ERROR, ALL 和 OFF, 默认debug
<root>可以包含零个或多个<appender-ref>元素,标识这个输出位置将会被本日志级别控制。
-->
<root level="ALL">
<!--设置控制台输出-->
<appender-ref ref="CONSOLE"/>
<!--设置在文件中输出-->
<appender-ref ref="FILE" />
</root>
</configuration>
代码示例
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Test {
//定义日志对象
public static final Logger LOGGER= LoggerFactory.getLogger("Test.java");
public static void main(String[] args) {
LOGGER.debug("main方法开始运行");
try {
LOGGER.trace("开始做除法");
int a=10,b=0;
LOGGER.info("a="+a);
LOGGER.info("b="+b);
int c=a/b;
} catch (Exception e) {
LOGGER.error("发生了异常:"+e);
}
}
}
本文介绍了日志技术的基本概念,重点阐述了Logback日志框架的体系结构、核心配置及其实现步骤。包括如何在项目中整合slf4j-api、logback-core和logback-classic,以及如何通过logback.xml进行日志级别设置和输出位置控制。实例演示了如何创建Logger对象并记录日志信息。
1597

被折叠的 条评论
为什么被折叠?



