服务命令不适用于 tomcat7

服务命令不适用于 tomcat7

我有一个全新安装的 Ubuntu 16.04,其中使用安装了 Tomcat7 apt-get install,并且在尝试使用命令与服务交互时遇到一些问题service

我知道如果系统上安装了 Tomcat,与该服务交互的正确方法是使用命令service

系统重启后,我看到 Tomcat7 正在按预期部署 war 应用程序,并且 Web 应用程序中的一切看起来都正常运行。

但如果我想重新启动 Tomcat:

sudo service tomcat7 restart

我在catalina.out日志中看到由于地址已被使用而导致的一些错误。有任何其他应用程序正在使用同一端口。

如果我尝试停止 tomcat,则像往常一样使用service tomcat7 stop

usr@Srv2:~$ sudo service tomcat7 stop
[sudo] password for qgenviewer: 
usr@Srv2:~$ ps -aux | grep tomcat7
tomcat7    1409  2.5  2.3 9268692 377788 ?      Sl   12:11   0:27     /usr/lib/jvm/java-7-openjdk-amd64/bin/java -Djava.util.logging.config.file=/var/lib/tomcat7/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.awt.headless=true -Xms512m -Xmx6144m -XX:+UseConcMarkSweepGC -Djava.endorsed.dirs=/usr/share/tomcat7/endorsed -classpath /usr/share/tomcat7/bin/bootstrap.jar:/usr/share/tomcat7/bin/tomcat-juli.jar -Dcatalina.base=/var/lib/tomcat7 -Dcatalina.home=/usr/share/tomcat7 -Djava.io.tmpdir=/tmp/tomcat7-tomcat7-tmp org.apache.catalina.startup.Bootstrap start
usr+   1762  0.0  0.0  21316   924 pts/0    S+   12:29   0:00 grep --    color=auto tomcat7

因此,看起来service命令不起作用,因为 Tomcat 仍在运行。如果我尝试service tomcat7 status,输出如下:

usr@Srv2:~$ sudo service tomcat7 status
● tomcat7.service - LSB: Start Tomcat.
   Loaded: loaded (/etc/init.d/tomcat7; bad; vendor preset: enabled)
   Active: failed (Result: exit-code) since vie 2016-05-06 12:11:29 CEST; 21min ago
     Docs: man:systemd-sysv-generator(8)
  Process: 1356 ExecStart=/etc/init.d/tomcat7 start (code=exited, status=1/FAILURE)
    Tasks: 38 (limit: 512)
   CGroup: /system.slice/tomcat7.service
           └─1409 /usr/lib/jvm/java-7-openjdk-amd64/bin/java -Djava.util.logging.config.file=/var/lib/tomcat7/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.C

may 06 12:11:24 Srv2 systemd[1]: Starting LSB: Start Tomcat....
may 06 12:11:24 Srv2 tomcat7[1356]:  * Starting Tomcat servlet  engine tomcat7
may 06 12:11:29 Srv2 tomcat7[1356]:    ...fail!
may 06 12:11:29 Srv2 systemd[1]: tomcat7.service: Control process exited, code=exited status=1
may 06 12:11:29 Srv2 systemd[1]: Failed to start LSB: Start Tomcat..
may 06 12:11:29 Srv2 systemd[1]: tomcat7.service: Unit entered failed state.
may 06 12:11:29 Srv2 systemd[1]: tomcat7.service: Failed with result 'exit-code'.
may 06 12:28:38 Srv2 systemd[1]: Stopped LSB: Start Tomcat..

有人能帮忙看看到底发生了什么吗……?它最终看起来似乎service tomcat7不起作用了。可能是什么原因造成的?那么,谁在系统启动时启动了 tomcat 服务?我该如何停止或重新启动 tomcat7 服务?

感谢您的时间。

编辑

为了提供更多信息,并遵循@Jens Grivolla 的建议,这是 pstree 的输出:

usr@Srv2:~$ pstree -lsup 1409
systemd(1)───java(1409,tomcat7)─┬─{java}(1412)
                                ├─{java}(1418)
                                 ...
                                ├─{java}(2262)
                                └─{java}(2313)

答案1

您可以尝试以下操作:

  • 首先获取正在运行的tomcat服务的PID,例如$ ps aux|grep tomcat
  • 然后尝试查看它是如何使用pstree(用来man pstree了解所使用的选项)启动的,例如

    $ pstree -lsup 26276
    systemd(1)───java(26276,tomcat7)─┬─{java}(26277)
                                     ├─{java}(26278)
                                     ├─{java}(26279)
                                     ├─{java}(26280)
                                     ├─...
                                     └─{java}(1252)
    

所以在我的例子中,它显然是由 systemd 启动的。如果你看到不同的东西,那么至少你知道该调查哪里...

相关内容