-
Log4j2-19-编程式配置 Programmatic Configuration
可编程配置
Log4j 2为应用程序提供了几种创建自己的编程配置的方法:
指定一个自定义的ConfigurationFactory,用程序化配置启动Log4j
启动Log4j后,使用配置器替换配置
使用配置文件和程序化配置的组合初始化Log4j
初始化后修改当前配置
ConfigurationBuild...
2016-05-21 02:00:13 |
Log
-
Log4j2-18-Plugins 插件
介绍
Log4j 1.X通过在大多数配置声明上要求类属性来允许扩展。
对于某些元素,特别是PatternLayout,添加新模式转换器的唯一方法是扩展PatternLayout类,并通过代码添加它们。
Log4j 2的一个目标是通过使用插件使扩展变得非常容易。
在Log4j 2中,插件是通过在类声明中添加 @Plugin 注解来声明的。
在初始化过程中,配置将调用PluginMan...
2016-05-21 02:00:13 |
Log
-
Log4j2-17-拓展 log4j
拓展 Log4j
Log4j 2提供了许多操作和扩展的方法。本节概述了Log4j 2实现直接支持的各种方式。
LoggerContextFactory
LoggerContextFactory将Log4j API绑定到它的实现。
Log4j LogManager通过使用java.util.ServiceLoader来定位org.apache.logging.log4j.spi.Pro...
2016-05-21 02:00:13 |
Log
-
Log4j2-16-Logging Separation 日志记录分离
日志记录分离
有许多众所周知的用例,其中应用程序可能与其他应用程序共享环境,并且每个应用程序都需要拥有自己的独立日志记录环境。
本节的目的是讨论其中的一些案例和实现这一目标的方法。
用例
本节描述了可以使用Log4j的一些用例以及它的预期行为。
独立应用程序
独立应用程序通常相对简单。它们通常有一个捆绑的可执行文件,只需要一个日志配置。
Web应用程序
典型的web应用程序将...
2016-05-21 02:00:13 |
Log
-
Log4j2-15-JMX 日志统计监控
JMX
Log4j 2内置了对JMX的支持。StatusLogger, ContextSelector,以及所有的LoggerContexts, LoggerConfigs和appeners都使用mbean进行检测,并且可以远程监视和控制。
还包括一个简单的客户端GUI,可用于监视StatusLogger输出,以及使用不同的配置文件远程重新配置Log4j,或直接编辑当前配置。
支持JM...
2016-05-21 02:00:13 |
Log
-
Log4j2-14-log4j2 无垃圾稳态日志 Garbage-free Steady State Logging
无垃圾稳态日志
垃圾收集暂停是导致延迟峰值的常见原因,对于许多系统来说,需要花费大量精力来控制这些暂停。
许多日志库,包括以前版本的Log4j,在稳态日志记录期间分配临时对象,如日志事件对象、字符串、char数组、字节数组等。这增加了垃圾收集器的压力,并增加了GC暂停发生的频率。
从2.6版本开始,Log4j在默认情况下以“无垃圾”模式运行,其中对象和缓冲区被重用,并且尽可能不分配临时...
2016-05-21 02:00:13 |
Log
-
Log4j2-13-log4j2 asyncLogger 低延迟日志的异步日志记录器
用于低延迟日志的异步日志记录器
异步日志记录可以通过在单独的线程中执行I/O操作来提高应用程序的性能。
Log4j 2在这方面做了许多改进。
异步记录器是Log4j 2中新增的功能。它们的目的是尽快从对Logger.log的调用返回到应用程序。
您可以选择让所有的logger都是异步的,或者混合使用同步和异步的logger。将所有记录器设置为异步将提供最佳性能,而混合将为您提供更多灵...
2016-05-21 02:00:13 |
Log
-
Log4j2-12-log4j2 过滤器 Filters
过滤器 Filters
过滤器允许对日志事件进行评估,以确定是否或如何发布它们。
Filter将在其过滤器方法之一上被调用,并将返回一个Result,这是一个Enum,具有3个值之一- ACCEPT, DENY或NEUTRAL。
过滤器可以配置在以下四个位置之一:
1) 上下文范围的过滤器直接在配置中配置。被这些筛选器拒绝的事件将不会传递给日志记录器进行进一步处理。
一旦事件被上下...
2016-05-21 02:00:13 |
Log