簡體   English   中英

在Servlet 3.0應用程序中使用log4j2

[英]Using log4j2 in Servlet 3.0 application

我正在嘗試在Servlet 3.0 Web應用程序中使用Log4j2。 即使按照官方文檔配置了所有內容,我也看不到日志。

這是我的web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
          http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
    version="3.0">

    <display-name>myapplication</display-name>

    <context-param>
        <param-name>isLog4jAutoInitializationDisabled</param-name>
        <param-value>true</param-value>
    </context-param>
    <context-param>
        <param-name>isLog4jContextSelectorNamed</param-name>
        <param-value>true</param-value>
    </context-param>

    <context-param>
        <param-name>log4jConfiguration</param-name>
        <param-value>log4j2.xml</param-value>
    </context-param>

    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
    </welcome-file-list>
</web-app>

我已經將log4j2.xml文件放在WEB-INF / classes中:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO">
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
        </Console>
        <File name="MyFile" fileName="myapplication.log" immediateFlush="true" append="false">
            <PatternLayout pattern="%d{yyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
        </File>
    </Appenders>
    <Loggers>
        <Root level="info">
            <AppenderRef ref="Console" />
            <AppenderRef ref="MyFile"/>
        </Root>
    </Loggers>
</Configuration>

這是我在課堂上給記錄器打電話的方式:

final static Logger LOGGER = Logger.getLogger(MyClass.class);
LOGGER.info("Logging works");

請告訴我我在做什么錯。 我什至嘗試過硬編碼log4j2.xml的直接路徑,但仍然無法正常工作。

Servlet 3.0 ,將isLog4jAutoInitializationDisabled設置為false或將其刪除,它應該可以工作。

如果您將其設置為true ,則將有其他步驟和要添加到web.xml

禁用自動初始化后,必須像處理Servlet 2.5 Web應用程序一樣初始化Log4j。

如果在Servlet 2.5 Web應用程序中使用Log4j,或者使用isLog4jAutoInitializationDisabled上下文參數禁用了自動初始化,則必須在部署描述符中或以編程方式配置Log4jServletContextListener和Log4jServletFilter。

看到這里Log4j2和Servlet 3.0

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM