我的编程空间,编程开发者的网络收藏夹
学习永远不晚

在Java中使用日志框架log4j的方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

在Java中使用日志框架log4j的方法

日志就是记录程序的运行轨迹,方便快速定位问题

如果用System.out.println(),信息是打印在控制台。等到产品上线后没有控制台,如果有报错信息,根本不知道去哪里看,就不知道是哪里出错。

而且开发的时候希望打印输出的内容多。方便排查,上线后只希望打印容易出错的部分。System.out.println()满足不了这个需求

而日志框架可以让错误信息输出到多个指定文件,不同的文件有不同的输出内容。方便排错,定位错误

一、log4j介绍

Log4j有三个主要的组件/对象:Loggers(记录器),Appenders (输出源)和Layouts(布局)。这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出。

每条日志语句都要设置一个等级(DEBUG、INFO、WARN、ERROR和FATAL)。

其中DEBUG < INFO < WARN < ERROR < FATAL。fatal等级最高

对应调试信息 一般信息 警告信息 错误信息 严重错误信息

1、Loggers

在设置日志输出位置的时候,会给那个位置设置一个级别,只有大于等于那个级别的日志才会打印输出到指定位置。

例如:某个Loggers(日志输出位置的等级记录器)级别设定为INFO,则INFO、WARN、ERROR和FATAL级别的日志信息都会输出到那个文件,而级别比INFO低的DEBUG则不会输出。

2、Appenders


禁用和使用日志请求只是Log4j的基本功能,Log4j日志系统还提供许多强大的功能,比如允许把日志输出到不同的地方,如控制台(Console)、文件(Files)等,可以根据天数或者文件大小产生新的文件,可以以流的形式发送到其它地方等等。

常使用的类如下:

org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

基本上可以满足我们的日常需求,当然如果你的需求比较特殊,可以自己实现Appender输出路径。只需要定义一个类,实现Appender接口就可以了。Appender接口中定义了一系列记录日志的方法,按照自己的规则实现这些方法即可

3、Layouts

用户可以根据自己的喜好格式化自己的日志输出,Layouts提供四种日志输出样式,如根据HTML样式、自由指定样式、包含日志级别与信息的样式和包含日志时间、线程、类别等信息的样式。

常使用的类如下:

org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等信息)

二、使用

在实际应用中,要使Log4j在系统中运行必须事先设定配置文件。配置文件事实上也就是对Logger、Appender及Layout进行相应设定。Log4j支持两种配置文件格式,一种是XML格式的文件,一种是properties属性文件,配置文件详解在下面使用部分说明

我是用maven创建项目

 1、导包

 在pom.xml


  <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>

2、创建配置文件

日志配置文件:log4j.properties文件或者logback.xml。

我用的是log4j.properties

在普通的se项目中放到class="lazy" data-src同级目录下,maven项目中放到class="lazy" data-src/main/resources目录下


### 日志的输出级别是dubug,输出位置名字叫stdout,D
log4j.rootLogger = debug,stdout,D
 
### 输出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
#用特定格式输出日志
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
#下面是规定好的格式,有点像c语言printf的%d,%m是输出代码中指定的消息的占位符
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
 
### 输出warn 级别以上的日志到文件里
# 文件位置为:D:/logs/error.log4j
log4j.appender.D = org.apache.log4j.FileAppender
log4j.appender.D.File = D:/logs/error.log4j
log4j.appender.D.Append = true
log4j.appender.D.Threshold = warn 
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

3、使用

在代码中使用Log4j


public class Test {
    @org.junit.Test
    public void testLog(){
        //1、获取日志记录器,这个记录器将负责控制日志信息
        //Name一般取当前类的名字
        Logger logger = Logger.getLogger(Test.class);
 
        //直接使用日志记录器,打印日志
        logger.debug("dubug级别");
        logger.error("error级别");
    }
}

最后结果:

控制台输出

磁盘中的文件输出

-------------------------------下面的太复杂------------------------------------

https://www.jb51.net/article/134950.htm

https://www.jb51.net/article/121581.htm


###配置日志根Logger
#第一参数是日志输出级别,这里是一个全局级别,只要它指定了error,下面不管设置什么比它的低级别都会失效,所以一般指定dubug
#后面几个参数都是日志输出的位置,多个输出路径用,隔开;随便起名只是一个代号
log4j.rootLogger=DEBUG,out1,out2,out3,out4
 
 
#ERROR 为严重错误 主要是程序的错误
#WARN 为一般警告,比如session丢失
#INFO 为一般要显示的信息,比如登录登出
#DEBUG 为程序的调试信息
 
#表示Logger的内容不会在父Logger的appender里输出,默认为true。
(?可能是这样,要输出日志时,得先创建一个Logger对象,用Logger对象打印,如果这里是true,日志内容不仅会出现在当前配置的日志文件里,还会出现在父类的日志文件里)
log4j.additivity.org.apache=false

下面的输出位置名字分别是 out1,out2,out3,out4


###配置日志信息输出目的地Appender,appender后面的参数对应log4j.rootLogger的位置名称
 
log4j.appender.out1=org.apache.log4j.ConsoleAppender #打印到控制台
log4j.appender.out1.Threshold=DEBUG #指定日志信息的最低输出级别,默认为DEBUG。
log4j.appender.out1.ImmediateFlush=true #表示所有消息都会被立即输出,设为false则不输出,默认值是true。
log4j.appender.out1.Target=System.err #默认值是System.out。?不知道是什么
log4j.appender.out1.layout=org.apache.log4j.PatternLayout #可以灵活地指定布局模式
log4j.appender.out1.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n  #布局格式
 
 
 
# 日志文件(logFile)
log4j.appender.logFile=org.apache.log4j.FileAppender
log4j.appender.logFile.Threshold=DEBUG
log4j.appender.logFile.ImmediateFlush=true
log4j.appender.logFile.Append=true
log4j.appender.logFile.File=D:/logs/log.log4j
log4j.appender.logFile.layout=org.apache.log4j.PatternLayout
log4j.appender.logFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n
 
 
### 输出到日志文件 ###
#org.apache.log4j.ConsoleAppender
#org.apache.log4j.FileAppender(文件)
#org.apache.log4j.DailyRollingFileAppender
#org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
#org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
#log4j.appender.error.Target=System.out

 logback.xml可以看:https://www.jb51.net/article/207994.htm

使用

在不同环境使用日志框架:https://www.jb51.net/article/74475.htm

https://www.jb51.net/article/207994.htm

https://www.jb51.net/article/197121.htm

到此这篇关于在Java中使用日志框架log4j的文章就介绍到这了,更多相关Java日志框架log4j内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

在Java中使用日志框架log4j的方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在Python 中使用loguru日志框架

如何在Python 中使用loguru日志框架?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。安装pip install loguru1、输出日志from log
2023-06-15

Java日志的使用方法

这篇文章将为大家详细讲解有关Java日志的使用方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4.
2023-06-14

Python 第三方日志框架loguru使用

解决中文乱码问题 项目地址 github: https://github.com/Delgan/loguru 文档:https://loguru.readthedocs.io/en/stable/index.html 安装pip insta
2022-06-02

Java接口测试中日志框架Logback该怎样使用

这篇文章主要为大家分析了Java接口测试中日志框架Logback该怎样使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“Java接口测试中日志框架Logba
2023-06-28

MySQL中binlog日志的使用方法

这篇文章主要介绍MySQL中binlog日志的使用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!binlog 就是binary log,二进制日志文件,这个文件记录了MySQL所有的DML操作。通过binlog日
2023-06-14

zap接收gin框架默认的日志并配置日志归档的方法

这篇“zap接收gin框架默认的日志并配置日志归档的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“zap接收gin框架默
2023-06-30

怎么在java中使用mybatis框架

怎么在java中使用mybatis框架?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程
2023-06-14

如何在java中使用WebMagic框架

本篇文章为大家展示了如何在java中使用WebMagic框架,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3.
2023-06-14

php中Libevent框架的使用方法

这篇文章主要介绍php中Libevent框架的使用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的语法混合了C、Java、Perl以及php自
2023-06-14

怎么在java中使用Spring框架

怎么在java中使用Spring框架?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系统
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录