我有一个 springboot Web 应用程序打包为 jar 文件。产品服务器为Ubuntu 14.04.1,安装了openjdk-8-jdk。
我可以使用以下命令成功运行应用程序:
sudo java -jar /home/myUser/my_web_app.jar
然后我通过以下命令将此应用程序作为 SystemV 服务:
sudo useradd webUser
sudo passwd webUser
sudo chown webUser:webUser /home/myUser/my_web_app.jar
sudo chmod 500 /home/myUser/my_web_app.jar
sudo ln -s /home/myUser/my_web_app.jar /etc/init.d/my_web_app
之后,当我运行时:
sudo service my_web_app start
错误引发为:
/etc/init.d/my_web_app: 1: /etc/init.d/my_web_app: Syntax error: ")" unexpected.
我想知道是什么原因导致此错误以及如何解决它。谢谢。
顺便说一句,同样的方法适用于我的开发机器(Ubuntu 14.04.6)。
最佳答案
问题出在这两行:
sudo chmod 500 /home/myUser/my_web_app.jar
sudo ln -s /home/myUser/my_web_app.jar /etc/init.d/my_web_app
问题 #1:常规可执行 JAR 文件不是操作系统可识别的可执行格式1。
在常规 JAR 文件上设置执行位不会有帮助。操作系统内核不知道如何运行它。要运行常规 JAR,您必须执行命令 java -jar/path/to/the.jar
。如有必要,您可以创建一个简单的包装脚本来执行此操作。
1 - 有一种方法可以生成特殊的“完全可执行”SpringBoot JAR 文件,该文件前面有一个 shell 脚本;请参阅"Installing Spring Boot Applications" 。这是解决此问题的一种方法,尽管文档指出这些特殊的 JAR 文件会导致某些工具出现问题。
问题 #2:/etc/init.d
中的文件应该是服务脚本。
它们不仅仅是服务的可执行文件。这些脚本应该是能够理解 start
、stop
、restart
、reload
等动词的 shell 脚本在。并且(据我所知)它们必须编码为与 sh
兼容的 shell 脚本。这里有一篇文章描述了服务脚本的结构:
(但请先阅读问题#4!!)
问题 #3:以 root
身份运行服务可能存在安全风险。
最好创建一个(非特权)服务帐户来运行该服务。如果服务暴露于网络,这一点尤其重要。 (如果坏人可以通过网络“破解”服务并导致其执行不需要的操作,那么它以 root 身份运行的事实就会使整个系统面临风险。)
问题#4: /etc/init.d/
脚本已过时。
如果您使用的是最新的 Ubuntu 版本(15.04 或更高版本),这些 /etc/init.d/
脚本是“传统”配置方式。 initd
机制的当前迭代是 systemd
。它使用 systemd 单元文件而不是服务脚本。以下文章提供了更多信息:
systemd
服务包含遗留服务脚本,但它们不像单元文件那样强大、灵活和……简洁。
问题 #5:Ubuntu 14.04 LTS 已终止生命周期。
您应该升级到 16.04 LTS,最好是 18.04 LTS。在生产服务器上使用生命周期结束的操作系统是不明智的。
<小时/>请注意,网络上有大量文档和许多关于配置服务的新旧方法的文章。 (Google 是你的 friend 。)
关于java - 在 ubuntu 14.04.1 上将 SpringBoot jar 部署为服务后出现语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56954414/