我有一个全新安装的 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 启动的。如果你看到不同的东西,那么至少你知道该调查哪里...