具有嵌入式init.d脚本的Spring Boot应用程序无法在重新启动时启动

时间:2016-06-10 23:26:52

标签: service spring-boot centos6 init.d

Spring Boot有一个方便的功能,如果您配置maven插件,它会将init.d starup脚本嵌入到可执行jar中: http://docs.spring.io/spring-boot/docs/current/reference/html/deployment-install.html#deployment-install

所以我使用上面的方法在Centos 6.6中“安装”一个Spring Boot应用程序(可执行的胖罐)作为服务。

到目前为止一切顺利。我创建了一个指向jar的链接并设置了权限:

sudo ln -s  /path/to/myapp.jar  /etc/init.d/my-service
sudo chmod 0755 /etc/init.d/my-service

我可以成功启动该应用程序:

sudo service my-service start

但是,我希望应用程序在启动时启动,因此我使用chkconfig实用程序:

sudo chkconfig --add my-service
sudo chkconfig my-service on

这些命令没有错误,但是当我重新启动Centos时,服务不会自动启动。 运行:

sudo service my-service status

所示:

Not running

跑步:

chkconfig --list my-service

所示:

my-service      0:off   1:off   2:on    3:on    4:on    5:on    6:off

一切看起来都不错,但它还没有开始。此时我可以通过“sudo service my-service start”手动启动服务并重新启动,但它不会在启动时自动启动。

有什么想法吗? 感谢

2 个答案:

答案 0 :(得分:2)

问题解决了。原来是路径问题和我的错。应用程序所在的路径是安装目录,该目录在引导时不可用。

答案 1 :(得分:0)

我遇到类似的问题,运行service myapp start

时收到以下错误消息
Exception in thread "main" java.lang.UnsupportedClassVersionError: org/springframework/boot/loader/JarLauncher : Unsupported major.minor version 52.0
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
    at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
Could not find the main class: org.springframework.boot.loader.JarLauncher. Program will exit.

但是我可以通过直接运行/etc/init.d/app start使它起作用。

最后,我发现问题是默认的jdk是1.6,尽管当前用户的java是1.8。然后我更改了符号,它起作用了。

enter image description here