Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/387.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/http/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用log4j在Java中记录运行时异常_Java_Spring_Tomcat_Logging_Log4j - Fatal编程技术网

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

使用log4j在Java中记录运行时异常,java,spring,tomcat,logging,log4j,Java,Spring,Tomcat,Logging,Log4j,我目前正在使用Tomcat、Spring和JAVA构建一个应用程序。我正在使用Log4J作为日志库。我目前正在将所有内容记录到一个文本文件中。我遇到的一个问题是,RuntimeExceptions没有被记录到任何文件中。我想知道是否有一种方法可以记录所有可能抛出到我的应用程序日志文件中的运行时异常。如果没有,是否可以将其记录到另一个日志文件?有没有标准的方法可以做到这一点?如果是这样的话,在Tomcat中运行应用程序时是否有一种标准的方法来实现这一点 提前感谢您的帮助 您可以尝试重定向StdEr

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


提前感谢您的帮助

您可以尝试重定向StdErr以使用记录器。这将输出写入std err的任何内容的结果(应包括未处理的异常)

这篇博客文章详细介绍了如何重定向到记录器中的FileHandler:


记录未捕获的运行时异常(或任何未捕获的可丢弃文件)的一种方法是创建一个实现的类。此类的
uncaughtException()
方法只需将异常详细信息写入日志。当未捕获的RuntimeException通过添加行终止线程时,可以让JVM调用此异常处理程序

Thread.setDefaultUncaughtExceptionHandler(new MyExceptionHandler());

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

默认的“未捕获异常处理程序”只需调用
可丢弃文件上的
printStackTrace()
,将堆栈跟踪打印到
System.err
。但是,您可以使用自己的日志将异常记录到log4j:

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);
  }

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

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));

你是说“未捕获”的运行时异常吗?是的,我是说“未捕获”的运行时异常这通常是应用程序中处理此运行时异常的方式吗?我想我想知道这是否是处理这个问题的一种标准方法。另外,我正在使用Spring API中的ThreadPoolTaskExecutor,这是否仍然可以使用这个类来完成?如果Runnable上存在RuntimeException,这非常有效,但是如果ThreadPoolTaskExecutor存在异常怎么办?假设它抛出RunTimeException,因为池的配置是正确的……这仍将打印到控制台,而不会被记录……有什么建议吗?您可能需要这两个工具,
UncaughtExceptionHandler
Runnable
包装器。未捕获异常处理程序将在创建和初始化执行器并提交任务执行的应用程序线程上设置。包装器用于提交的任务。Spring愚蠢地混淆了运行时异常和已检查异常,因此帮助它摆脱这种混乱的解决方案可能并不完美请?