tomcat 8 服务文件的权限不起作用

use*_*425 6 tomcat ubuntu systemd

我正在尝试在 ubuntu 16.04 上安装 tomcat 8。这是我遵循的指南:

https://www.digitalocean.com/community/tutorials/how-to-install-apache-tomcat-8-on-ubuntu-16-04

基本思想是您应该创建一个名为“tomcat”的附加用户,该用户具有运行 tomcat 的有限权限。当我尝试运行最终命令以作为服务启动时(以 root 身份尝试):

sudo systemctl start tomcat
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

tomcat.service 的作业失败,因为控制进程退出并显示错误代码。有关详细信息,请参阅“systemctl status tomcat.service”和“journalctl -xe”。

检查 systemctl 状态:

tomcat.service - Apache Tomcat Web Application Container
Loaded: loaded (/etc/systemd/system/tomcat.service; disabled; vendor preset: enabled)
Active: activating (auto-restart) (Result: exit-code) 
Process: 14 ExecStart=/opt/tomcat/bin/startup.sh (code=exited, status=203/EXEC)

systemd[1]: Starting Apache Tomcat Web Application Container...
systemd[1]: tomcat.service: Control process exited, code=exited status=203
systemd[1]: Failed to start Apache Tomcat Web Application Container.
systemd[1]: tomcat.service: Unit entered failed state.
systemd[1]: tomcat.service: Failed with result 'exit-code'.
Run Code Online (Sandbox Code Playgroud)

这是 tomcat.service 文件:

# /etc/systemd/system/tomcat.service

[Unit]
Description=Apache Tomcat Web Application Container
After=network.target

[Service]
Type=forking

Environment=JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-amd64
Environment=CATALINA_PID=/opt/tomcat/temp/tomcat.pid
Environment=CATALINA_HOME=/opt/tomcat
Environment=CATALINA_BASE=/opt/tomcat
Environment='CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC'
Environment='JAVA_OPTS=-Djava.awt.headless=true -Djava.security.egd=file:/dev/./urandom'

ExecStart=/opt/tomcat/bin/startup.sh
ExecStop=/opt/tomcat/bin/shutdown.sh

User=tomcat
Group=tomcat
RestartSec=10
Restart=always

[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)

这些是对 /tomcat/bin 文件夹的访问权限:

-rwxr-x--- 1 root root   1902 Jul  6 08:44 shutdown.sh
-rwxr-x--- 1 root root   1904 Jul  6 08:44 startup.sh
... 
Run Code Online (Sandbox Code Playgroud)

其他用户报告了同样的问题,并建议将整个“tomcat”文件夹的所有权授予“tomcat”用户。但这似乎与文章的精神相冲突(限制访问以提高安全性)。

我不确定我是否遗漏了本文中有关权限的隐含内容?

谢谢

小智 5

只需删除您到目前为止所做的一切。然后:

sudo apt-get install tomcat8
sudo service tomcat8 start
Run Code Online (Sandbox Code Playgroud)


Zin*_*ina 0

按照文章看了,也出现了和你一样的错误。

之后:

chgrp -R tomcat bin chmod g+rwx bin chmod g+r bin/*

它对我有用。

无需更改 /opt/tomcat 中的所有文件/文件夹(仅更改启动、关闭以及这两个文件/文件夹调用的文件/文件夹 - 这就是我使用整个 bin 文件夹的原因)。

顺便说一句,您还可以创建apt-get install tomcat8一个工作 tomcat8 服务器:)(这将创建一个 ID 低于 1000 的 tomcat8 用户/组)。