我想使用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]
我在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>