一. 引言

1.1 日志介绍

  • 用于记录系统中发生的各种事件. 记录的位置常见的有: 控制台, 磁盘文件等

1.2 日志级别

  • 日志级别由低到高

    • TRACE, DEBUG, INFO, WARN, ERROR, FATAL

1.3 日志的作用

  • 通过日志观察, 分析项目的运行情况(项目维护)
  • 通过日志分析用户的使用情况(大数据分析)
  • ...

二. 解决方案1

2.1 Log4j + Commons-Logging

2.1.1 导入依赖
  • 项目中导入Log4j 和 Commons-Logging的依赖
<!--log4j-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!--commons-logging-->
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
2.1.2 基本使用
  • Log4j + Commons-Logging基本API
package com.dz.test;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.junit.Test; public class LogTest {
//日志对象
private Log log = LogFactory.getLog(LogTest.class);
@Test
public void test() {
log.trace("hello trace");
log.debug("hello debug");
log.info("hello info");
log.warn("hello warn");
log.error("hello error");
log.fatal("hello fatal");
}
}
2.1.3 配置信息
  • 定义配置文件 log4j.xml
#占位符
%p: 输出优先级, 即 DEBUG, INFO, WARN, ERROR, FATAL
%r: 输出自应用启动到输出该log信息耗费的毫秒数
%c: 输出所在类的全名
%t: 输出产生该日志事件的线程名
%n: 输出一个回车换行符
%d: 输出日志时间点的日期或时间, 默认格式为ISO8601, 也可以在其后指定格式, 比如: %d{yyyy-MM-dd HH:mm:ss,SSS}, 输出类似: 2021-01-01 15:26:37,945
%l: 输出日志事件的发生位置, 包括类名, 发生的线程, 以及在代码中的行数. 举例: Testlo4.main(TestLog4.java:10)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//LOGGER"
"http://org/apache/log4j/xml/log4j.dtd">
<log4j:configuration> <!--输出到控制台-->
<appender name="myConsole" class="org.apache.log4j.ConsoleAppender">
<!--输出格式-->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
</layout>
</appender>
<!--输出到文件-->
<appender name="myFile1" class="org.apache.log4j.RollingFileAppender">
<param name="File" value="d:/log/hello1.log"/><!--文件位置-->
<param name="Append" value="true"/><!--是否选择追加-->
<param name="MaxFileSize" value="1kb"/><!--文件最大字节数-->
<param name="MaxBackupIndex" value="2"/><!--新文件数量-->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
</layout>
</appender>
<!--输出到文件-->
<appender name="myFile2" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="d:/log/daily.log"/><!--文件位置-->
<param name="Append" value="true"/><!--是否选择追加-->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n"/>
</layout>
</appender>
<!--根logger的设置-->
<root>
<!--优先级设置 all < trace < debug < info < warn < error < fatal < off-->
<priority value="debug"/>
<appender-ref ref="myConsole"/>
<appender-ref ref="myFile1"/>
<appender-ref ref="myFile2"/>
</root>
</log4j:configuration>

三. 解决方案2

3.1 Logback + SLF4j

3.1.1 导入依赖
  • 项目中导入依赖
<!--logback依赖, 还会传递 slf4j 和 logback-core-->
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
<scope>test</scope>
</dependency>
3.1.2 基本使用
  • Logback + SLF4j 基本API
package com.dz.test;

import org.junit.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; public class LogTest {
//需要输出日志的类, 可以创建一个log属性
private Logger log = LoggerFactory.getLogger(LogTest.class);
@Test
public void test() throws InterruptedException { log.trace("hello trace");
log.debug("hello debug 张三");
log.info("hello info 张三");
log.warn("hello warn 张三");
log.error("hello error 张三");
//注意: logback中没有fatal日志
}
}
3.1.3 配置信息
  • 定义 logback.xml
#占位符
%d{yyyy-MM-dd HH:mm:ss,SSS}: 日期
%5p: 日志级别, 5位字符长度显示, 如果内容占不满5位则内容右对齐并在左侧补空格
%-5p: 5位字符长度显示日志级别, 如果内容占不满5位则内容左对齐并在右侧补空格, -代表左对齐
%logger: 日志所在包和类
%M: 日志所在方法名
%L: 日志所在代码行
%m: 日志正文
%n: 换行

<?xml version="1.0" encoding="UTF-8"?>
<!--scan: 当此属性设置为true时, 配置文件如果发生改变, 将会被重新加载, 默认值为true-->
<!--scanPeriod: 设置检测配置文件是否有修改时间的时间间隔, 如果没有给出时间单位, 默认单位是毫秒.
当scan为true时, 此属性生效, 默认的时间间隔为1分钟-->
<!--debug: 当此属性设置为true时, 将打印出logback内部日志信息, 实时查看logback运行状态. 默认值为false-->
<configuration scan="true" scanPeriod="60 seconds" debug="true">
<!--定义变量, 可通过 ${log.path}和${CONSOLE_LOG_PATTERN} 得到变量值-->
<property name="log.path" value="d:/log"/>
<property name="CONSOLE_LOG_PATTERN"
value="%d{yyyy-MM-dd HH:mm:ss.SSS} |-{%-5p} in %logger.%M[line-%L] -%m%n"/> <!--输出到控制台-->
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<!--Threshold=即是最低日志级别, 此appender输出大于等于对应级别的日志
(当然还要满足root中定义的最低级别)
-->
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>debug</level>
</filter>
<encoder>
<!--日志格式(引用变量)-->
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern>
<!--设置字符集-->
<charset>UTF-8</charset>
</encoder>
</appender>
<!--追加到文件中-->
<appender name="file1" class="ch.qos.logback.core.FileAppender">
<file>${log.path}/hello.log</file>
<encoder>
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern>
</encoder>
</appender>
<!--滚动追加到文件中-->
<appender name="file2" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--正在记录的日志文件的路径及文件名-->
<file>${log.path}/logback.log</file>
<!--日志文件输出格式-->
<encoder>
<Pattern>${CONSOLE_LOG_PATTERN}</Pattern>
<charset>UTF-8</charset><!--设置字符集-->
</encoder>
<!--日志记录器的滚动策略, 按日期,按大小记录
文件超过最大尺寸后, 会创建文件, 然后新的日志文件中继续写入
如果日期变更, 也会新建文件, 然后在新的日志文件中写入当天日志
-->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!--新建文件后, 原日志改名为如下: %i=文件序号, 从0开始-->
<fileNamePattern>${log.path}/logback-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<!--每个日志文件的最大体量-->
<timeBasedFileNamingAndTriggeringPolicy
class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>1kb</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
<!--日志文件保留天数 1=只保留昨天的归档日志文件, 不设置则保留所有日志-->
<maxHistory>1</maxHistory>
</rollingPolicy>
</appender> <root level="trace">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="file1"/>
<appender-ref ref="file2"/> </root>
</configuration>

7_Log的更多相关文章

  1. 安全基线自动化扫描、生成报告、加固的实现(以Tomcat为例)

    一.背景说明 当前在服务上线前,安全部门都会对服务基线配置进行把关,整个流程可以分为扫描.生成报告.修复三步. 在执行这一流程时当前普遍的做法是半自动化的,扫描和生成报告是自动化的,执行扫描.执行生成 ...

随机推荐

  1. 01-vscode自定义配色方案 插件基础上

    01-下载相关主题插件 02- 点击设置按钮 复制id 03-进入插件文件 C:\Users\Administrator\.vscode\extensions 04-复制刚才的id 05-themes ...

  2. 【学习笔记】带你从0开始学习 01Trie

    01Trie Section 1:普通 Trie Section 1.1 什么是 Trie Trie 树,即字典树,是一种树形结构.典型应用是用于统计和排序大量的字符串前缀来减少查询时间,最大限度地减 ...

  3. pathlib相关操作

    简介 python中操作文件或者文件夹的模块目前我知道的有四个,分别为os.shutil.pathlib.glob,在了解到pathlib之前,我一直使用的是os进行相关路径的操作,但在使用了path ...

  4. @DS("slave") 多数据源兼容事务问题解决方案

    SpringBoot项目中用到多数据源,在方法上又必须加事务处理,此时可以对使用了@DS的方法或类添加@Transactional并添加事务隔离级别 举例: 1.这是一个方法,方法内需要实现多数据源查 ...

  5. 工作效率-十五分钟让你快速学习Markdown语法到精通排版实践备忘

    关注「WeiyiGeek」公众号 设为「特别关注」每天带你玩转网络安全运维.应用开发.物联网IOT学习! 希望各位看友[关注.点赞.评论.收藏.投币],助力每一个梦想. 文章目录: 0x00 前言简述 ...

  6. 原型设计工具Axure RP9下载、汉化操作说明(赠授权码)

    Axure是产品经理.交互设计常用的一款原型设计工具,能实现比较复杂的交互效果.其实在功能上是十分齐全的,并且其交互的样式也比较多样,主要是通过动态面板.函数.中继器等几个模块就几乎可以实现任何常见的 ...

  7. 使用.NET简单实现一个Redis的高性能克隆版(一)

    译者注 该原文是Ayende Rahien大佬业余自己在使用C# 和 .NET构建一个简单.高性能兼容Redis协议的数据库的经历. 首先这个"Redis"是非常简单的实现,但是他 ...

  8. GTID主从和lamp架构运行原理

    目录 GTID主从 GTID概念介绍 GTID工作原理 GTID主从配置 lamp lamp简介 web服务器工作流程 cgi与fastcgi http协议 是什么? lamp架构运行的原理 Apac ...

  9. DolphinScheduler 功能开发:⼯作流级别任务空跑(后端),测试工作流是否正确执行...

    点击上方 蓝字关注我们 ✎ 编 者 按 在今年由中国科学院软件研究所主办的开源软件所供应链点亮计划-开源之夏活动中,有不少小伙伴提交了关于 DolphinScheduler 的项目,本期是来自成都信息 ...

  10. EMAS Serverless系列~4步教你快速搭建小程序

    体验简介 本实验基于 EMAS Serverless 的云函数.云数据库.云存储等云服务能力一站式快速开发小程序<私人云相册>.Demo 主要包括如下功能: 1 相册管理 2 上传相片 3 ...