首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用log4j在Java中记录运行时异常

使用log4j在Java中记录运行时异常
EN

Stack Overflow用户
提问于 2010-02-27 04:35:48
回答 2查看 25.4K关注 0票数 24

我目前正在使用Tomcat、Spring和JAVA构建一个应用程序。我使用Log4J作为我的日志库。我目前正在将所有内容记录到一个文本文件中。我遇到的一个问题是RuntimeExceptions没有被记录到任何文件中。我想知道是否有一种方法可以将可能抛出到我的应用程序日志文件中的所有RuntimeExceptions记录下来。如果没有,是否可以将其记录到另一个日志文件中?有没有一种标准的方法来做到这一点?如果是这样的话,在Tomcat中运行应用程序时,有没有一种标准的方法可以做到这一点?

提前感谢您的帮助!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-02-27 05:04:06

我不确定这是否是您想要的,但是有一个异常处理程序可以终止线程。它是未被线程的目标显式捕获的任何异常的处理程序。

默认的“未捕获异常处理程序”只是在Throwable上调用printStackTrace(),将堆栈跟踪打印到System.err。但是,您可以使用您自己的UncaughtExceptionHandlerreplace它,它将异常记录到log4j中:

代码语言:javascript
复制
class Log4jBackstop implements Thread.UncaughtExceptionHandler {

  private static Logger log = Logger.getLogger(Log4jBackstop.class);

  public void uncaughtException(Thread t, Throwable ex) {
    log.error("Uncaught exception in thread: " + t.getName(), ex);
  }

}

如果您正在使用向其传递Runnable对象的executor框架,则其线程可能具有自己的catch块,以防止异常到达未捕获的异常处理程序。如果您想在那里捕获Runtime异常,一种方法是将每个任务包装在日志包装器中,如下所示:

代码语言:javascript
复制
class Log4jWrapper {

  private final Logger log;

  private final Runnable target;

  Log4jWrapper(Logger log, Runnable target) { 
    this.log = Objects.requireNonNull(log);
    this.target = Objects.requireNonNull(target); 
  }

  public void run() {
    try {
      target.run();
    } catch(RuntimeException ex) {
      log.error("Uncaught exception.", ex);
      throw ex;
    }
  }

}

...

Runnable realTask = ...;
executor.submit(new Log4jWrapper(Logger.getLogger(Whatever.class), realTask));
票数 25
EN

Stack Overflow用户

发布于 2010-02-27 04:59:39

记录未捕获的RuntimeExceptions (或任何未捕获的Throwable)的一种方法是创建一个实现Thread.UncaughtExceptionHandler的类。该类的uncaughtException()方法将简单地将异常详细信息写入日志。只要未捕获的RuntimeException通过添加以下行终止线程,就可以使JVM调用此异常处理程序。

代码语言:javascript
复制
Thread.setDefaultUncaughtExceptionHandler(new MyExceptionHandler());

添加到您的代码。

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

https://stackoverflow.com/questions/2344654

复制
相关文章

相似问题

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