Java异常日志,但没有完整的堆栈信息

在客户现场以及测试环境,有时候会遇到异常堆栈日志不全的情况,从而导致无法准确定位问题。
于是网络上搜索相关的信息,发现需要增加jvm参数:

-XX:-OmitStackTraceInFastThrow

根据资料 https://stackoverflow.com/questions/2411487/nullpointerexception-in-java-with-no-stacktrace 可知:

优化之处在于,当第一次发生异常(通常是 NullPointerException)时,会打印完整的堆栈跟踪,并且 JVM 会记住堆栈跟踪(或者可能只是代码的位置)。 当该异常发生得足够频繁时,将不再打印堆栈跟踪,这样既可以实现更好的性能,又不会用相同的堆栈跟踪淹没日志。

又因为为docker部署,所以通过在docker-compose.yaml文件中增加对应的配置,重启服务,通过查看cmd命令,可知已经增加了对应的配置
image.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,我们可以通过创建自定义异常来提供更详细的错误信息。自定义异常类继承自Java提供的Exception或其子类,对于需要打印非堆栈信息的自定义异常,我们可以通过重写Exception类的toString()方法来实现。 在自定义异常类中,我们可以添加额外的成员变量来保存非堆栈信息,例如错误代码、错误描述等。然后,在toString()方法中,可以通过格式化字符串的方式将这些信息打印出来。 以下是一个示例的自定义异常类: ```java public class MyException extends Exception { private int errorCode; private String errorMessage; public MyException(int errorCode, String errorMessage) { this.errorCode = errorCode; this.errorMessage = errorMessage; } @Override public String toString() { return "错误代码:" + errorCode + "\n错误描述:" + errorMessage; } } ``` 在使用该自定义异常类的时候,我们可以通过创建异常对象,并将非堆栈信息传递给构造方法来初始化异常对象。当异常被抛出并捕获时,可以通过调用异常对象的toString()方法来获取非堆栈信息并打印出来。 以下是一个使用自定义异常类的示例: ```java public class Main { public static void main(String[] args) { try { throw new MyException(1001, "自定义异常测试"); } catch (MyException e) { System.out.println(e.toString()); } } } ``` 运行上述代码,将输出自定义异常的非堆栈信息: ``` 错误代码:1001 错误描述:自定义异常测试 ``` 通过重写Exception类的toString()方法,我们可以自定义异常的非堆栈信息的格式和内容,从而提供更详细的错误信息供调试和日志记录使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值