JVM返回错误143
在Windows 2003上作为计划任务运行的Java应用程序崩溃,没有任何日志或任何有助于找出发生的事情的内容。 唯一可用的信息是应用程序返回代码143(8F)。 从计划任务日志中检索到该错误代码。
有谁知道错误代码(143)代表什么? 注销用户是否可能导致应用程序终止?
谢谢,
JVM错误代码143表示内部字段必须有效 。 这在OTN论坛上进行了讨论 。 然而,结论似乎是一个杀死你的过程的东西。
我怀疑这可能是由用户注销造成的。
143通常意味着应用程序因SIGTERM命令而终止。 另见https://unix.stackexchange.com/questions/10231/when-does-the-system-send-a-sigterm-to-a-process
但请注意,应用程序可能会使用143作为自己的自定义结果。
用户注销将向所有正在运行的进程发出CTRL_LOGOFF_EVENT
信号。 来自https://msdn.microsoft.com/en-us/library/windows/desktop/aa376876(v=vs.85).aspx :
系统还在注销操作期间向每个进程发送CTRL_LOGOFF_EVENT控制信号。
现在,在某些情况下,它将使用错误代码143
( SIGTERM
)终止Java应用程序。 请参阅https://bugs.openjdk.java.net/browse/JDK-6871190 。
好吧,无论如何,你需要阻止这种情况发生的是用-Xrs
选项启动Java。 来自https://www.ibm.com/support/knowledgecenter/SSYKE2_8.0.0/com.ibm.java.win.80.doc/diag/appendixes/cmdline/Xrs.html :
设置-Xrs可防止Java™运行时环境处理任何内部或外部生成的信号,如SIGSEGV和SIGABRT。
因此,您应该使用以下内容启动Java应用程序:
>java -Xrs -jar myapplication.jar
PS:
SIGTERM
和143
号码之间的关系在https://unix.stackexchange.com/questions/10231/when-does-the-system-send-a-sigterm-to-a-process#comment13523_10231中有说明。