`

log4j中的MDC和NDC

阅读更多
NDC和MDC
NDC(Nested Diagnostic Context)和MDC(Mapped Diagnostic Context)是log4j种非常有用的两个类,它们用于存储应用程序的上下文信息(context infomation),从而便于在log中使用这些上下文信息。

NDC采用了一个类似栈的机制来push和pop上下文信息,每一个线程都独立地储存上下文信息。比如说一个servlet就可以针对每一个request创建对应的NDC,储存客户端地址等等信息。
当使用的时候,我们要尽可能确保在进入一个context的时候,把相关的信息使用NDC.push(message);在离开这个context的时候使用NDC.pop()将信息删除。另外由于设计上的一些问题,还需要保证在当前thread结束的时候使用NDC.remove()清除内存,否则会产生内存泄漏的问题。
存储了上下文信息之后,我们就可以在log的时候将信息输出。在相应的PatternLayout中使用”%x”来输出存储的上下文信息,下面是一个PatternLayout的例子:
%r [%t] %-5p %c{2} %x - %m%n
使用NDC最重要的好处就是,当我们想输出一些上下文的信息的时候,不需要让logger去寻找这些信息,而只需要在适当的位置进行存储,然后再配置文件中修改PatternLayout。在最新的log4j 1.3版本中增加了一个org.apache.log4j.filters.NDCMatchFilter,用来
根据NDC中存储的信息接受或拒绝一条log信息。

MDC和NDC非常相似,所不同的是MDC内部使用了类似map的机制来存储信息,上下文信息也是每个线程独立地储存,所不同的是信息都是以它们的key值存储在”map”中。相对应的方法,MDC.put(key, value); MDC.remove(key); MDC.get(key); 在配置PatternLayout的时候使用:%x{key}来输出对应的value。同样地,MDC也有一个org.apache.log4j.filters.MDCMatchFilter。这里需要注意的一点,MDC是线程独立的,但是一个子线程会自动获得一个父线程MDC的copy。
至于选择NDC还是MDC要看需要存储的上下文信息是堆栈式的还是key/value形式的。

动态修改日志配置
在开发过程中,我们经常会遇到修改log4j配置的情况,在这种情况下,频繁重启应用显然是不可接受的。幸好log4j提供了自动重新加载配置文件的能力,在配置文件修改后,便会自己重新加载配置。在1.2及以前的版本中DOMConfigurator和PropertyConfigurator都提供了configureAndWatch方法,对指定的配置文件进行监控,并且可以设置检查的间隔时间。
分享到:
评论

相关推荐

    log4j-API-最新稳定版本log4j-1.2.17

    7. **MDC(Mapped Diagnostic Context)和NDC(Nested Diagnostic Context)**:这两个特性提供了上下文信息,帮助追踪和调试多线程环境中的问题。 8. **自定义日志等级和日志事件**:开发者可以通过继承`Priority`...

    log4j jarjar包

    Log4j,作为Java领域中最流行和广泛使用的日志框架之一,因其强大的功能和灵活性,深受开发者的喜爱。本文将深入探讨Log4j的核心概念,以及如何在项目中使用log4j-1.2.16.jar这个关键的jar包。 一、Log4j简介 Log4...

    Log4J完整说明和配置

    在深入分析配置文件之前,我们先了解几个Log4J中的核心概念: - **Logger**:负责接收并处理日志信息的对象。 - **Appender**:指定日志信息的输出目的地。 - **Layout**:定义日志信息的格式。 - **Level**:设置...

    java-日志-log4j.7z

    此外,Log4j还支持MDC(Mapped Diagnostic Context)和NDC(Nested Diagnostic Context),这些特性可以附加上下文信息到日志记录中,对于调试多线程和分布式系统非常有用。 如果你对Log4j的具体使用还有疑问,可以...

    apache-log4j-2.4.1-bin.zip

    Apache Log4j 2是Java世界中广泛使用的日志记录框架之一...在实际项目中,你可以根据“apache-log4j-2.4.1-bin.zip”中的内容进行安装和配置,快速地将Log4j 2集成到你的Java应用程序中,享受它带来的便利和性能提升。

    log4j简单使用

    8. **MDC (Mapped Diagnostic Context)** 和 **NDC (Nested Diagnostic Context)**: 这两个特性提供了在日志中附加上下文信息的能力,对于跟踪请求、事务或线程很有用。 9. **使用示例**: 在代码中,我们通常会这样...

    log4j多个简单实例

    MDC(Mapped Diagnostic Context)和NDC(Nested Diagnostic Context)是Log4j提供的上下文诊断工具。它们可以用来存储与线程相关的诊断信息,便于在复杂环境中追踪问题。 通过以上实例,你已经了解了Log4j的基本...

    log4j中文手册

    Appender在Log4j中是负责将日志输出到目的地的组件。Log4j提供了多种Appender,比如ConsoleAppender用于将日志输出到控制台,FileAppender用于将日志输出到文件,DailyRollingFileAppender用于每天自动滚动写入到...

    log4j-slf4j-impl.zip

    5. **MDC与NDC**:Log4j-SLF4J-Impl支持Mapped Diagnostic Context (MDC) 和Nested Diagnostic Context (NDC),为日志信息添加上下文信息,有助于追踪和诊断问题。 四、集成与使用 集成Log4j-SLF4J-Impl通常涉及...

    log4j-2.11.1.jar

    《Apache Log4j 2.11.1:Java日志框架的核心组件》 Apache Log4j 是一个广泛使用的开源日志记录框架,为Java应用程序提供了强大的日志处理能力。...在实际项目中,正确配置和使用Log4j 2.11.1,将使日志工作事半功倍。

    log4j生成带时间戳的日志文件(包括extras包以及简单demo)

    在Log4j中,我们可以自定义日志格式来包含时间戳。例如,在`log4j.properties`配置文件中添加以下内容: ``` log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n ``` ...

    log4j-1.2.17含源码

    此外,Log4j 1.2.17还支持MDC(Mapped Diagnostic Context)和NDC(Nested Diagnostic Context),这两个功能提供了上下文信息,帮助追踪问题。MDC是线程绑定的,而NDC可以嵌套,两者在调试多线程和复杂系统时特别...

    log4j-core-2.7.zip

    描述中提到,Struts2版本2.5.10.1依赖于Log4j2,这意味着开发者在使用该版本的Struts2时,需要引入两个关键的Log4j2库:log4j-api-2.7和log4j-core-2.7。log4j-api-2.7提供了API接口,供应用程序调用,而log4j-core-...

    log4j-1.2.17.jar

    4. **Appender与Layout**:在Log4j中,Appender负责将日志信息输出到特定目的地,而Layout则决定日志信息的格式。常见的Appender有ConsoleAppender(控制台)、FileAppender(文件)和SMTPAppender(电子邮件),...

    log4j入门、详解

    **日志框架Log4j详解** 日志框架在软件开发中扮演着至关重要的角色,它提供了记录应用程序运行过程中的各种事件的功能,...在实际项目中,结合具体需求,合理运用Log4j的各种特性,能极大地提升开发效率和维护体验。

    log4j记录Debug日志

    9. **MDC与NDC**:Mapped Diagnostic Context (MDC) 和 Nested Diagnostic Context (NDC) 是Log4j提供的两个特性,用于存储与当前线程相关的诊断信息,帮助追踪问题。 10. **日志切割与归档**:Log4j可以配置自动...

    apache-log4j-2.9.0-src.zip

    3. **日志事件**:`LogEvent`是Log4j中的关键数据结构,它封装了日志信息,如时间戳、级别、logger名、消息和异常等。日志事件通过`Appender`发送到指定的输出目标。 4. **日志布局与模板**:Log4j提供了多种布局...

    log4j使用例子和文档

    - **MDC(Mapped Diagnostic Context)与NDC(Nested Diagnostic Context)**: 用于存储与线程相关的诊断信息,方便追踪和调试。 总之,Log4j作为一个强大的日志工具,其灵活性和可扩展性使其成为Java开发者首选的...

    Log4j2 web demo (log4j2 version 2.1)

    Log4j2允许你基于MDC(Mapped Diagnostic Context)或NDC(Nested Diagnostic Context)进行日志过滤。例如,你可以添加一个MDC键值对来区分不同的用户请求: ```java MDC.put("userId", "123456"); // 记录日志 ...

    log4j-1.2.17

    Apache Log4j作为Java领域中最广泛使用的日志框架之一,其1.2.17版本具有稳定性和兼容性的优势,深受开发者喜爱。本文将详细解析log4j-1.2.17的核心概念、功能以及实际应用。 一、Log4j简介 Log4j是一个开源的日志...

Global site tag (gtag.js) - Google Analytics