我在Ubuntu 18.04上安装了Redis和Tomcat的分发包。我试图在 Redis 成功启动后才启动 Tomcat,但到目前为止还没有成功。
tomcat8 包在 /etc/init.d/tomcat8 中有 sysv init 脚本,我看到生成的 /run/systemd/generator.late/tomcat8.service。
Redis-server 包在 /lib/systemd/system/redis-server.service 中有服务单元
我在这些目录中创建了指向 redis-server 的符号链接:
ln -s /lib/systemd/system/redis-server.service /etc/systemd/system/tomcat8.service.requires/redis-server.service
ln -s /lib/systemd/system/redis-server.service /etc/systemd/system/tomcat8.service.after/redis-server.service
但是,如果我故意挑起 Redis 启动失败,Tomcat 无论如何都会启动。我希望 Tomcat 在 Redis 失败时不启动。
我看到了 Tomcats 服务状态命令的输出,“LSB 依赖失败”,但 Tomcat 还是启动了:
root@elkarel:/home/elkarel# service tomcat8 status
tomcat8.service - LSB: Start Tomcat.
Loaded: loaded (/etc/init.d/tomcat8; generated)
Active: active (running) since Mon 2019-07-01 14:57:51 CEST; 2min 7s ago
Docs: man:systemd-sysv-generator(8)
Process: 690 ExecStart=/etc/init.d/tomcat8 start (code=exited, status=0/SUCCESS)
Tasks: 44 (limit: 2340)
CGroup: /system.slice/tomcat8.service
└─737 /usr/lib/jvm/java-8-oracle/bin/java -Djava.util.logging.config.file=/var/lib/tomcat8/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.awt.head
Jul 01 14:57:45 elkarel systemd[1]: Starting LSB: Start Tomcat....
Jul 01 14:57:45 elkarel systemd[1]: Dependency failed for LSB: Start Tomcat..
Jul 01 14:57:45 elkarel systemd[1]: tomcat8.service: Job tomcat8.service/start failed with result 'dependency'.
Jul 01 14:57:46 elkarel tomcat8[690]: * Starting Tomcat servlet engine tomcat8
Jul 01 14:57:51 elkarel tomcat8[690]: ...done.
我systemctl daemon-reload
每次做任何改变都会执行。
我没有改变包文件,我也不想,但现在我怀疑是否有可能只用符号链接来声明这种依赖关系。
没有
.after/
,只有.wants/
和.requires/
。结果,您的两个服务都排队等待同时启动。失败的 Requires= 依赖项应该导致 tomcat8 再次停止,但是...... SysV 生成的服务在涉及到这一点时很奇怪。您需要将其他设置添加到内部的 .conf 文件中
<unit>.d/
(例如,通过使用systemctl edit tomcat8
):注意:您应该避免使用 .wants/ 或 .requires/ 进行一般自定义,因为这些目录中的符号链接可能会在“systemctl enable/disable”期间意外删除。为其他所有内容创建 .conf 文件或完整单元覆盖。