daZ*_*Zza 0 shell error-handling
我刚刚将工作的 Windows 批处理脚本 (.bat) 迁移到 Unix Shell。通常它工作得很好,但是,我刚刚意识到在 Unix 中返回的错误级别是错误的。
从我所读到的,%errorlevel%
Windows 中的命令“翻译”到$?
Unix 中。但是,当在脚本中调用的 Java 应用程序执行期间发生错误时,Windows Batch 脚本会返回错误级别 4。
Unix$?
返回 0 而不是 4,这会导致我的自动错误检查将实际有问题的应用程序运行解释为成功。
如何让 Unix 返回正确的错误级别?据我所知,当发生错误时,它实际上应该返回> 0 的值......
这是我的shell脚本:
JAVA_HOME="/usr/lib/jvm/java"
EXECUTABLE="my.java.executable"
BASEDIR=`dirname $0`
cd $BASEDIR
LOCAL_CP=$BASEDIR
for f in `find $BASEDIR/lib -type f -name "*.jar"` `find $BASEDIR/lib -type f -name "*.zip"`
do
LOCAL_CP=$LOCAL_CP:$f
done
# various variables being assigned
VMARGS="-various -vmargs -assigned -here"
$JAVA_HOME/bin/java $VMARGS -cp $LOCAL_CP $EXECUTABLE $various_variables
echo $status
echo ERRORLEVEL: $?
Run Code Online (Sandbox Code Playgroud)
以及来自 Java 应用程序的日志。请注意最后返回的错误级别为 0:
2016/08/22 20:00:22 - Start XXX (stdout) - java.lang.IllegalStateException: EJBCLIENT000025: No EJB receiver available for handling [appName:xxx, moduleName:xxx-ejb-generic, distinctName:] combination for invocation context org.xxx.EJBClientInvocationContext@50a638b5
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.EJBClientContext.requireEJBReceiver(EJBClientContext.java:727)
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.ReceiverInterceptor.handleInvocation(ReceiverInterceptor.java:116)
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.EJBClientInvocationContext.sendRequest(EJBClientInvocationContext.java:183)
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.sendRequestWithPossibleRetries(EJBInvocationHandler.java:253)
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.doInvoke(EJBInvocationHandler.java:198)
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.doInvoke(EJBInvocationHandler.java:181)
2016/08/22 20:00:22 - Start XXX (stdout) - at org.xxx.invoke(EJBInvocationHandler.java:144)
2016/08/22 20:00:22 - Start XXX (stdout) - at com.sun.proxy.$Proxy2.evalWorkflowStatus(Unknown Source)
2016/08/22 20:00:22 - Start XXX (stdout) - at xxx.ejb.workflow.test.ClientAsyncComStrategy.startWorkflow(ClientAsyncComStrategy.java:83)
2016/08/22 20:00:22 - Start XXX (stdout) - at xxx.ejb.workflow.test.yyy.startWorkflow(yyy.java:219)
2016/08/22 20:00:22 - Start XXX (stdout) - at xxx.ejb.workflow.test.yyy.main(yyy.java:132)
2016/08/22 20:00:22 - Start XXX (stdout) -
2016/08/22 20:00:22 - Start XXX (stdout) - null
2016/08/22 20:00:22 - Start XXX (stdout) - ERRORLEVEL: 0
Run Code Online (Sandbox Code Playgroud)
预先感谢您可以给我的任何提示!
您的echo
命令设置自己的状态:
echo $status
echo ERRORLEVEL: $?
Run Code Online (Sandbox Code Playgroud)
如果你想保留它,你应该把它保存到一个变量中:
rc=$?
echo $status
echo ERRORLEVEL: $rc
exit $rc
Run Code Online (Sandbox Code Playgroud)