1. 看不到异常堆栈信息
OmitStackTraceInFastThrow
JVM自带的Fast Throw机制,当同一位置多次抛出同一类型异常时,详细的异常栈信息会被清空,这样异常抛出的速度比较快,打印堆栈信信息时只会简单地打印相关异常类,如java.lang.NullPointerException,不会打印详细的堆栈信息。
NullPointerException
ArithmeticException
ArrayIndexOutOfBoundsException
ArrayStoreException
ClassCastException
JVM默认会开启Fast Throw优化,如果想要关闭Fast Throw优化,可以在启动参数加上配置-XX:-OmitStackTraceInFastThrow即可。
2. 消费消息时没有正常消费,看不到相关异常
消费消息时记得捕获异常,不然很难排查到具体异常位置。