在Debian系统下,编写Tomcat的启动脚本可以通过创建一个systemd服务单元文件来实现。以下是一个详细的步骤指南:
首先,确保你已经下载并安装了Tomcat。你可以从Tomcat官方网站下载最新版本的Tomcat。
wget https://archive.apache.org/dist/tomcat/tomcat-9/v9.0.56/bin/apache-tomcat-9.0.56.tar.gz
tar xvf apache-tomcat-9.0.56.tar.gz -C /opt
ln -s /opt/apache-tomcat-9.0.56 /opt/tomcat
创建一个新的Systemd服务单元文件 /etc/systemd/system/tomcat.service
。
sudo nano /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-11-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
UMask=0007
RestartSec=10
Restart=always
[Install]
WantedBy=multi-user.target
为了安全起见,建议为Tomcat创建一个专用的用户和组。
sudo groupadd tomcat
sudo useradd -s /bin/false -g tomcat -d /opt/tomcat tomcat
确保Tomcat目录及其子目录和文件的所有权属于新创建的用户和组。
sudo chown -R tomcat:tomcat /opt/tomcat
sudo chmod +x /opt/tomcat/bin/*.sh
重新加载Systemd配置以识别新的服务单元文件。
sudo systemctl daemon-reload
启动Tomcat服务并设置为开机自启。
sudo systemctl start tomcat
sudo systemctl enable tomcat
检查Tomcat服务的状态以确保其正常运行。
sudo systemctl status tomcat
如果一切正常,你应该会看到Tomcat服务正在运行。
如果你使用的是UFW防火墙,可以配置它以允许HTTP和HTTPS流量。
sudo ufw allow 8080/tcp
sudo ufw allow 8443/tcp
通过以上步骤,你就可以在Debian系统下成功编写并运行Tomcat的启动脚本。