Ber*_*ems 2 java configuration logging log4j log4j2
我正在使用 log4j-core-2.5 进行日志记录,并且我想在日志记录队列已满时丢弃项目。我确定可以通过使用 log4j 中的 log4j2.asyncQueueFullPolicy 配置属性来应用此功能。
有人可以帮助我如何在我的应用程序中应用此配置吗?
我正在使用这样的文件配置......
Configurator.initialize("", "log4j-node.xml");
Run Code Online (Sandbox Code Playgroud)
我的配置文件看起来像这样
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="debug">
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<ThresholdFilter level="DEBUG" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout pattern="[%d{dd-MMM HH:mm:ss.SSS} %logger{1}.%t %-5level] %msg%n"/>
</Console>
<RollingFile name="DefaultFile" fileName="../logs/app.log"
filePattern="../logs/app-%d{MM-dd-yyyy}-%i.log" bufferedIO="true" bufferedSize="32000" immediateFlush="false">
<ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
...
</RollingFile>
<Async name="AsyncFile">
<AppenderRef ref="DefaultFile"/>
<LinkedTransferQueue/>
</Async>
<Async name="AsyncConsole">
<AppenderRef ref="Console"/>
<LinkedTransferQueue/>
</Async>
</Appenders>
<logger name="org.hibernate">
<level value="debug" />
</logger>
<Loggers>
<Root level="TRACE">
<AppenderRef ref="AsyncConsole"/>
<AppenderRef ref="AsyncFile"/>
</Root>
<Logger name="org.hibernate.SQL" level="error" />
<!-- Log all JDBC parameters -->
<Logger name="org.hibernate.type" level="error" />
<!-- Log all SQL DDL statements as they are executed -->
<Logger name="org.hibernate.tool.hbm2ddl" level="error" />
<!-- Log the state of all entities (max 20 entities) associated with the session at flush time -->
<Logger name="org.hibernate.pretty" level="error" />
<!-- Log all second-level cache activity -->
<Logger name="org.hibernate.cache" level="error" />
<!-- Log transaction related activity -->
<Logger name="org.hibernate.transaction" level="error" />
<!-- Log all JDBC resource acquisition -->
<Logger name="org.hibernate.jdbc" level="error" />
<!-- Log HQL and SQL ASTs during query parsing -->
<Logger name="org.hibernate.hql.ast.AST" level="error" />
<!-- Log all JAAS authorization requests -->
<Logger name="org.hibernate.secure" level="error" />
<!-- Log everything (a lot of information, but very useful for troubleshooting) -->
<Logger name="org.hibernate" level="error" />
</Loggers>
</Configuration>
Run Code Online (Sandbox Code Playgroud)
干杯
首先,请升级到 Log4j 2.10,它解决了该领域的一个重要问题,即当队列已满时,日志事件不再按顺序出现在日志文件中。
您可以通过系统属性配置Log4j2的行为log4j2.AsyncQueueFullPolicy。请参阅AsyncQueueFullPolicy和AsyncQueueFullPolicyFactory。具有某种日志级别的“丢弃”策略可能会令人感兴趣。
属性
log4j2.AsyncQueueFullPolicy控制路由行为。如果未指定此属性或具有 value"Default",则此工厂将创建DefaultAsyncQueueFullPolicy对象。如果此属性具有 value
"Discard",则此工厂创建DiscardingAsyncQueueFullPolicy对象。默认情况下,如果队列已满,该路由器将丢弃 INFO、DEBUG 和 TRACE 级别的事件。这可以通过属性log4j2.DiscardThreshold(开始丢弃的级别的名称)进行调整。
| 归档时间: |
|
| 查看次数: |
2757 次 |
| 最近记录: |