当前位置: 首页 > article >正文

第三百零六节 Log4j教程 - Log4j日志级别

Log4j教程 - Log4j日志级别

org.apache.log4j.Level类具有以下级别。

我们还可以通过对Level类进行子类化来定义我们的自定义级别。

级别描述
ALL所有级别包括自定义级别。
DEBUG调试消息日志。
ERROR错误消息日志,应用程序可以继续运行。
FATAL严重错误消息日志,必须中止运行应用程序。
INFO信息消息。
OFF最高可能的排名,旨在关闭日志记录。
TRACE高于DEBUG。
WARN用于警告消息。

控制级别

在Log4j中,级别是有序的。

如果A>= Y,则在级别为Y的记录器中启用级别X的日志请求。

对于标准级别,我们有ALL <DEBUG<INFO<WARN<ERROR<FATAL<OFF。

以下示例显示如何过滤所有DEBUG和INFO消息。

它使用logger方法 setLevel(Level.XXX)设置所需的日志记录级别。

以下代码打印除Debug和Info之外的所有消息:

import org.apache.log4j.*;

public class Main {
   private static org.apache.log4j.Logger log = Logger
                                    .getLogger(Main.class);
   public static void main(String[] args) {
      log.setLevel(Level.WARN);

      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

当你编译和运行LogClass程序时,它将产生以下结果:

Warn Message!
Error Message!
Fatal Message!

使用配置文件设置级别

我们可以使用Log4j配置文件来控制日志级别设置,而不更改源代码。

以下代码显示如何通过配置文件执行log.setLevel(Level.WARN)。

# Define the root logger with appender file
log = c:/log4j
log4j.rootLogger = WARN, FILE

# Define the file appender
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=${log}/log.out

# Define the layout for file appender
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%m%n

现在让我们使用我们的下面的程序:

import org.apache.log4j.*;

public class Main {
   private static org.apache.log4j.Logger log = Logger.getLogger(Main.class);
   public static void main(String[] args) {
      log.trace("Trace Message!");
      log.debug("Debug Message!");
      log.info("Info Message!");
      log.warn("Warn Message!");
      log.error("Error Message!");
      log.fatal("Fatal Message!");
   }
}

http://www.kler.cn/a/374327.html

相关文章:

  • Python学习的自我理解和想法(22)
  • 论文翻译 | PROMPTAGATOR : FEW-SHOT DENSE RETRIEVAL FROM 8 EXAMPLES
  • CentOS8.5.2111(4.1)数据中心主DNS部署
  • 《战场车辆及部件损毁识别与评估的神经网络迁移训练》
  • 使用LangChain控制大模型的输出——解析器Parser
  • 【JavaEE】【多线程】进阶知识
  • kubevirt cloud-init配置
  • 【解决方案】用git reset --hard重置了提交但是发现reset了一些本不该reset的内容,是不是寄了?
  • Android 圆形进度条CircleProgressView 基础版
  • Linux 程序地址空间
  • python读取视频并转换成gif图片
  • Python爬虫之urllib库详解
  • 【论文阅读笔记】VLP: A Survey on Vision-language Pre-training
  • 基于AI深度学习的中医针灸实训室腹针穴位智能辅助定位系统开发
  • mac-ubuntu虚拟机(扩容-共享-vmtools)
  • Oracle视频基础1.3.3练习
  • sql题库中常见问答
  • 【青牛科技】GC4921替代BD6921/罗姆在水泵、筋膜枪、吸尘器和电动工具中的应用
  • Django中分组查询(annotate 和 aggregate 使用)
  • 从0开始搭建一个生产级SpringBoot2.0.X项目(六)RestTemplate调用第三方接口
  • fastGPT添加知识库文本索引模型m3e一直处于索引中怎么解决
  • 练习LabVIEW第二十八题
  • SSM复习——M(MyBatis)二
  • VR动捕数据手套如何配合头显装置进行机器臂遥操作?
  • 阳振坤:云时代数据库的思考 | OceanBase发布会实录
  • [Java基础] Integer和int使用注意点