java中开源日志记录工具log4j

日志:除了能记录异常信息,还可以记录程序正常运行时的关键信息。

使用log4j来进行日志文件记录经典步骤:

001.在项目中创建一个lib文件夹,然后将下载好的jar包copy到该文件夹下

002.对已经copy过来的jar包,点击右键,然后执行下图操作,

项目中就会多出一个引入外部Library的项目

003.在src目录下创建一个名称为log4j.properties文件

004.编写,粘贴已经写好的配置文件内容,编码方式可以做下修正。对配置文件点击右键→属性→other→utf-8,然后应用确定即可。如果再次报错,不理会他,点击确定,再次Ctrl+S即可。

005.就是在main方法所在类中,添加如下代码

//首先是创建一个静态的Logger对象

public static Logger logger=Logger.getLogger("log4j");

接下来就可以通过logger.debug(“日志内容”);

注意事项:通过反编译源码我们知道,getLogger方法,有两个重载。

我们当前使用的是传入字符串的重载,经过多方资料验证,括号中传入任何内容对抽象工厂产生出一个Logger实例时没有任何影响的。所以可以放心使用。

  其中 [level] 是日志输出级别,共有5级:

  FATAL       0  
  ERROR      3  
  WARN       4  
  INFO         6  
  DEBUG      7 

  输出级别优先级:

 all<Trace<debug<info<warn<error<fatal<off

  Appender 为日志输出目的地,Log4j提供的appender有以下几种:

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

  Layout:日志输出格式,Log4j提供的layout有以下几种:

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

  

  配置文件:

  log4j.rootLogger = debug,A,B,C,

  # 输出到控制台

  log4j.appender.A = org.apache.log4j.ConsoleAppender

  log4j.appender.A.Target = System.out

  log4j.appender.A.layout = org.apache.log4j.PatternLayout

  log4j.appender.A.layout.ConversionPattern = %p %t %c - %m%n

  

  # 输出到日志文件

  log4j.appender.B = org.apache.log4j.DailyRollingFileAppender

  log4j.appender.B.File = logs/log.log

  log4j.appender.B.Append = true

  log4j.appender.B.Threshold = DEBUG # 输出EBUG级别以上的日志

  log4j.appender.B.layout = org.apache.log4j.PatternLayout

  log4j.appender.B.layout.ConversionPattern = %p %t %c - %m%n

  # 保存异常信息到单独文件

  log4j.appender.C = org.apache.log4j.DailyRollingFileAppender

  log4j.appender.C.File = logs/error.log # 异常日志文件名

  log4j.appender.C.Append = true

  log4j.appender.C.Threshold = ERROR #只输出ERROR级别以上的日志

  log4j.appender.C.layout = org.apache.log4j.PatternLayout

  log4j.appender.C.layout.ConversionPattern = %p %t %c - %m%n

问题:

如何使用log4j记录日志?

解析:引入jar包

创建properties文件

编写log4j配置代码

log4j记录日志

时间: 2024-09-30 19:39:45

java中开源日志记录工具log4j的相关文章

跟王老师学异常(八):开源日志记录工具log4j的使用案例

开源日志记录工具log4j的使用 主讲人:王少华  QQ群号:483773664 学习目标 掌握Log4J在java项目中的应用 一.日志分类及log4j介绍 (一)日志及分类 1 日志 主要用来记录系统运行中一些重要操作信息 便于监视系统运行情况,帮助用户提前发现和避开可能出现的问题,或者出现问题后根据日志找到原因 2.分类 SQL日志:记录系统执行的SQL语句 异常日志:记录系统运行中发生的异常事件 业务日志:记录系统运行过程.如用户登录.操作记录 (二)Log4j介绍 Log4j是Apac

【学习笔记】开源日志记录工具log4j使用方法

一.在MyEclipse中使用log4j的步骤比较简单,主要分为以下四个步骤: 1.在项目中加入log4j所使用的jar文件. 2.创建log4j.properties文件. 3.编写log4j.properties文件,配置日志文件. 4.在程序中使用log4j记录日志信息. 二.日志根据记录内容的不同,主要分成以下三类: 1.SQL日志:记录系统执行的SQL语句. 2.异常日志:记录系统运行中发生的异常事件. 3.业务日志:记录系统运行过程,如用户登录.操作记录. 三.log4j的下载 要使

开源日志记录工具log4j

前言:当我们进行大的项目书写的时候或者我们选择维护程序的时候,想知道几点几时我们录入的数据有bug是那么我们就采用--------------------------->log4j记录日志的信息 一.日志及其分类 1.软件运行的过程中离不开日志.日志主要用来记录系统运行过程中的一些重要操作信息,便于监视系统运行的情况,帮助用户避免和发现可能出现的问题,或者出现问题后根据日志找到发生的原因. 2.日志根据记录内容不同主要分为以下三类: SQL日志:记录系统执行的SQL语句 异常日志:记录系统运行中

Java学习-007-Log4J 日志记录配置文件详解及实例源代码

此文主要讲述在初学 Java 时,常用的 Log4J 日志记录配置文件详解及实例源代码整理.希望能对初学 Java 编程的亲们有所帮助.若有不足之处,敬请大神指正,不胜感激!源代码测试通过日期为:2015-1-30 13:54:02,请知悉. 所需的 jar 包下载链接为:http://yunpan.cn/cKE56sxqtQCfP  访问密码 63d8 有关 Log4J 日志文件中日志级别及文件配置的详细情况,在 Log4J 的配置文件(xml.properties)中有详细的介绍,敬请参阅!

java中的日志打印

java中的日志打印: 日志工具类: 1 #获取日志 INFO:表示获取日志的等级 A1:表示日志存器,可以自定义名称 2 #===DEBUG INFO 3 log4j.rootLogger=DEBUG,A1,A2,A3 4 5 6 7 ########################控制台日志#################################### 8 9 #定义日志A1存放器 10 11 log4j.appender.A1=org.apache.log4j.ConsoleAp

在Java中开源的数据库连接池

在Java中开源的数据库连接池有以下几种 : 1, C3P0 C3P0是一个开放源代码的JDBC连接池,它在lib目录中与Hibernate一起发布,包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSources 对象. https://github.com/swaldman/c3p0 2,Proxool 这是一个Java SQL Driver驱动程序,提供了对你选择的其它类型的驱动程序的连接池封装.可以非常简单的移植到现存的代码中.完全可配

Linux笔记之终端日志记录工具script

在学习Linux时,有时候终端的打印消息对于我们非常重要,但是终端显示也是有一定的缓冲空间的,当打印信息非常多时,前面的信息就会被覆盖掉,所以这里网上搜索了一下这方面的介绍,现总结如下: script 是一个非常使用的工具,同时也足够的好玩.script 能够将终端的会话过程录制下来,然后使用 scriptreplay 就可以将其录制的结果播放给他人观看.script 的好处就在于,你在终端中的所有操作过程,它都可以原原本本地进行录制.我们可以将这种录制应用在很多方面,诸如教学.演示等等. 一般

封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil

封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,代码比较简单,主要是把MongoTarget的配置.FileTarget的配置集成到类中,同时利用缓存依赖来判断是否需要重新创建Logger类,完整代码如下: using NLog; using NLog.Config; using NLog.Mongo; using NLog.Targets; using System; using System.Collections.Generic; using System.IO;

java中IO写文件工具类

下面是一些根据常用java类进行组装的对文件进行操作的类,平时,我更喜欢使用Jodd.io中提供的一些对文件的操作类,里面的方法写的简单易懂. 其中jodd中提供的JavaUtil类中提供的方法足够我们使用,里面的方法写的非常简练,例如append,read等方法,封装更好,更符合面向对象, 这里面我写的一些方法可多都是模仿jodd,从里面进行抽取出来的. /** * 获取路径文件夹下的所有文件 * @param path * @return */ public static File[] ge