提问者:小点点

将spring boot jar作为服务运行时,意外标记附近出现语法错误


我想使用init.d将基于Spring Boot的应用程序作为服务运行(服务器是Redhat 5.9)。

运行service myapp start/etc/init. d/myapp start时,我收到以下错误:

/etc/init.d/myapp: line 168: syntax error near unexpected token `>'
/etc/init.d/myapp: line 168: `    $command &>> "$log_file" &

我运行了sh-x /etc/init.d/myappstatus来查看发生了什么,但对我帮助不大。这是输出的最后一部分:

+ PID_FOLDER=/var/run/myapp
+ pid_file=/var/run/myapp/myapp.pid
+ log_file=/app/myapp//myapp.log
++ id -u
+ [[ 0 == \0 ]]
++ awk '{print $3}'
++ ls -ld /app/myapp/myapp-server-0.0.1-SNAPSHOT.jar
+ run_user=myapp
+ [[ -n /usr/java/default ]]
+ [[ -x /usr/java/default/bin/java ]]
+ javaexe=/usr/java/default/bin/java
+ command='/usr/java/default/bin/java -Dsun.misc.URLClassPath.disableJarChecking=true  -jar /app/myapp/myapp-server-0.0.1-SNAPSHOT.jar  '
/etc/init.d/myapp: line 168: syntax error near unexpected token `>'
/etc/init.d/myapp: line 168: `    $command &>> "$log_file" &'

我有一个<代码>。我的jar旁边的conf文件:

[root@appdev02 myapp]# cat myapp-server-0.0.1-SNAPSHOT.conf
MODE=service
LOG_FOLDER=/app/myapp/
JAVA_HOME=/usr/java/default

我正在使用Spring Boot 1.3.1

更新:我降级到了Spring Boot 1.3.0,一切都开始正常:

[root@appdev02 ~]# service myapp start
which: no start-stop-daemon in (/sbin:/usr/sbin:/bin:/usr/bin)
Started [19564]

共1个答案

匿名用户

我在OSX上遇到过这个问题,这是因为旧版本的bash不喜欢

$command &>> "$log_file" &

收件人:

$command >> "$log_file" 2>&1

我注意到脚本中的其他地方使用了原始语法,我建议Spring Boot人员在他们的根脚本中进行更改。

在此之前,我建议复制脚本,进行上述编辑,保存新脚本并将其用作embedded lanch script——如果使用mvn,则按如下方式完成:

<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <configuration>
        <executable>true</executable
<embeddedLaunchScript>${basedir}/src/main/resources/embeddedLaunchScript.bash</embeddedLaunchScript>
    </configuration>
</plugin>