-XX:OnOutOfMemoryError ="<cmd> <arg>"给出错误:无法找到或加载主类<arg>

msf*_*sfk 0 bash shell quotes jvm

我已将JAVA_OPTS设置为

export JAVA_OPTS="$JAVA_OPTS -server -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -Xloggc:gc.log  -Dcom.sun.management.jmxremote.ssl=false -Xms100m -Xmx100m -XX:MaxPermSize=5M -XX:ReservedCodeCacheSize=100m -Xss100k -XX:NewRatio=2 -XX:+UseParallelOldGC -XX:+UseParallelGC -XX:CompileThreshold=100  -XX:HeapDumpPath=/usr/share/$package -XX:-HeapDumpOnOutOfMemoryError -XX:OnError=$TEMP_CMD -XX:OnOutOfMemoryError=$TEMP_CMD"
Run Code Online (Sandbox Code Playgroud)

然后我正在运行命令"trinidad -p"

在$ TEMP_CMD中,如果我使用不带任何参数的命令,则会发生OutOfMemoryError,并且$ TMP_CMD命令也会运行.但是如果我在命令中使用任何参数,则会显示以下输出

Error: Could not find or load main class <arg>
Run Code Online (Sandbox Code Playgroud)

arg是争论

有人能给我解决方案吗?

在trinidad.yml或任何其他cofig文件中是否有任何更改?

Vad*_*zim 6

尝试

export JAVA_OPTS="... \"-XX:OnError=$TEMP_CMD\" ..."

要么

export JAVA_OPTS='... "-XX:OnError=$TEMP_CMD" ...'

请参阅Bash嵌套引号和eval以及http://www.grymoire.com/Unix/Quote.html.

更新

测试后,上述内容似乎仍无效.

test.sh

JAVA_OPTS="$JAVA_OPTS -Xmx32m '-XX:OnOutOfMemoryError=echo %p'"
java $JAVA_OPTS Test
Run Code Online (Sandbox Code Playgroud)

$ bash -x ./test.sh
+ JAVA_OPTS=' -Xmx32m '\''-XX:OnOutOfMemoryError=echo %p'\'''
+ java -Xmx32m ''\''-XX:OnOutOfMemoryError=echo' '%p'\''' Test
Exception in thread "main" java.lang.NoClassDefFoundError: '-XX:OnOutOfMemoryError=echo
Run Code Online (Sandbox Code Playgroud)

失败.

JAVA_OPTS="$JAVA_OPTS -Xmx32m -XX:OnOutOfMemoryError=\"echo %p\""
java $JAVA_OPTS Test
Run Code Online (Sandbox Code Playgroud)

$ bash -x ./test.sh
+ JAVA_OPTS=' -Xmx32m -XX:OnOutOfMemoryError="echo %p"'
+ java -Xmx32m '-XX:OnOutOfMemoryError="echo' '%p"' Test
Exception in thread "main" java.lang.NoClassDefFoundError: %p"
Run Code Online (Sandbox Code Playgroud)

失败.

使用-xbash选项进行诊断有助于谷歌解决问题的根源是bash变量替换和单词拆分规则的奇怪组合:http://mywiki.wooledge.org/BashFAQ/050.

有几种可能的解决方法.

1)使用帮助程序脚本来摆脱顽固的空间

JAVA_OPTS+=" -Xmx32m -XX:OnOutOfMemoryError=/usr/tmp/test/oom.sh"
java $JAVA_OPTS Test
Run Code Online (Sandbox Code Playgroud)

2)OnOutOfMemoryError移出变量

JAVA_OPTS="$JAVA_OPTS -Xmx32m"
java $JAVA_OPTS -XX:OnOutOfMemoryError="echo %p" Test
Run Code Online (Sandbox Code Playgroud)

$ bash -x ./test.sh
+ JAVA_OPTS=' -Xmx32m'
+ /usr/java/jdk1.6.0_16/bin/java -Xmx32m '-XX:OnOutOfMemoryError=echo %p' Test
#
# java.lang.OutOfMemoryError: Java heap space
# -XX:OnOutOfMemoryError="echo %p"
#   Executing /bin/sh -c "echo 1639"...
1639
Run Code Online (Sandbox Code Playgroud)