首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Log4j2内存泄漏

Log4j2内存泄漏
EN

Stack Overflow用户
提问于 2017-12-29 06:13:33
回答 1查看 2K关注 0票数 1

我到处寻找这个问题的解决方案,现在我开始怀疑这是否真的是一个问题。

我将log4j2作为记录器引入到我的应用程序中,当我这样做时,在重新加载、取消部署或停止Tomcat服务器8.5.24时,会留下内存泄漏,只有在我将记录器引入代码中时才会发生这种情况。

我在pom.xml中的依赖项

代码语言:javascript
复制
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.10.0</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.10.0</version>
</dependency>

我的WebServlet

代码语言:javascript
复制
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.LogManager;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

@WebServlet(name = "Servlet", urlPatterns = {"/servlet"}, loadOnStartup = 1)
public class Servlet extends HttpServlet {

    private final Logger logger = LogManager.getLogger(Servlet.class);

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        logger.info("doGet");

        PrintWriter out = response.getWriter();
        out.print("Servlet loaded");
        out.flush();
        out.close();
    }

}

我的log4j2.xml

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
    <Appenders>
        <Console name="Console">
            <PatternLayout pattern="%d %p %c %m%n" />
        </Console>
        <File name="File" bufferedIO="true" fileName="logs/log4j2-file-sync-${date:HH:MM:ss.SSS}.log">
            <PatternLayout pattern="%d %p %c %m%n" />
        </File>
    </Appenders>
    <Loggers>
        <Root level="all" includeLocation="false">
            <AppenderRef ref="Console" />
            <AppenderRef ref="File" />
        </Root>
    </Loggers>
</Configuration>

这是我得到的错误:

代码语言:javascript
复制
The following web applications were stopped (reloaded, undeployed), but their
classes from previous runs are still loaded in memory, thus causing a memory
leak (use a profiler to confirm):
/myapp
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-12-30 19:25:50

为了回答我自己的问题,感谢来自评论的@RemkoPopma和来自Tomcat JIRA董事会的@RalphGoers的建议。

我的pom.xml中只需要以下依赖项,它还导入coreapi,并处理Log4J2的正确关闭。

代码语言:javascript
复制
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-web</artifactId>
    <version>2.10.0</version>
</dependency>

可以找到此依赖项的特定文档

https://logging.apache.org/log4j/2.x/manual/webapp.html

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48015024

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档