在Debian系統上部署Apache Tomcat應用時,遵循最佳實踐非常重要,以確保系統的穩定性、安全性和性能。以下是一些關鍵步驟和最佳實踐:
安裝Java Development Kit (JDK): 在部署Tomcat之前,需要安裝JDK??梢允褂靡韵旅畎惭bOpenJDK:
sudo apt update
sudo apt install default-jdk
下載并解壓Tomcat:
從Apache Tomcat官方網站下載最新版本的Tomcat,并解壓到指定目錄,例如/opt/tomcat
。
wget http://www-us.apache.org/dist/tomcat/tomcat-9/v9.0.76/bin/apache-tomcat-9.0.76.tar.gz
tar -zxvf apache-tomcat-9.0.76.tar.gz -C /opt/tomcat/
創建Tomcat用戶和組: 為了安全起見,建議創建一個專用的系統用戶和組來運行Tomcat。
sudo groupadd tomcat
sudo useradd -s /bin/false -g tomcat -d /opt/tomcat tomcat
配置Tomcat權限: 設置適當的權限,確保Tomcat用戶可以訪問其安裝目錄和相關文件。
sudo chown -R tomcat:tomcat /opt/tomcat
sudo chmod -R 755 /opt/tomcat/bin/*.sh
創建systemd服務文件: 創建一個systemd服務文件來管理Tomcat服務,使其在系統啟動時自動啟動。
sudo nano /etc/systemd/system/tomcat.service
內容示例:
[Unit]
Description=Tomcat 9.0 servlet container
After=network.target
[Service]
Type=forking
User=tomcat
Group=tomcat
Environment="JAVA_HOME=/usr/lib/jvm/default-java"
Environment="CATALINA_PID=/opt/tomcat/temp/tomcat.pid"
Environment="CATALINA_HOME=/opt/tomcat/latest"
Environment="CATALINA_BASE=/opt/tomcat"
Environment="CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC"
ExecStart=/opt/tomcat/latest/bin/startup.sh
ExecStop=/opt/tomcat/latest/bin/shutdown.sh
[Install]
WantedBy=multi-user.target
重新加載systemd并啟動Tomcat:
sudo systemctl daemon-reload
sudo systemctl start tomcat
sudo systemctl enable tomcat
/opt/tomcat/latest/conf/tomcat-users.xml
文件,添加管理用戶及其權限。<tomcat-users>
<role rolename="manager-gui"/>
<role rolename="admin-gui"/>
<user username="admin" password="password" roles="manager-gui,admin-gui"/>
</tomcat-users>
/etc/default/tomcat
文件,修改默認安全配置為no
。sudo nano /etc/default/tomcat
修改以下行:TOMCAT_SECURITY_CONFIG="no"
調整JVM參數:
編輯Tomcat的啟動腳本(如catalina.sh
),調整JVM內存參數,如初始堆大?。?code>-Xms)和最大堆大?。?code>-Xmx)。
export CATALINA_OPTS="-Xms256m -Xmx512m -Xmn256m"
啟用垃圾回收器: 選擇合適的垃圾回收器,如G1GC,并在啟動腳本中添加相應參數。
export CATALINA_OPTS="$CATALINA_OPTS -XX:UseG1GC"
調整線程池大小:
在server.xml
文件中設置maxThreads
屬性,以設定Tomcat創建的最大線程數。
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
maxThreads="200"/>
logback-spring.xml
文件中配置日志記錄路徑和格式,以便監控和分析Tomcat的運行狀態。<configuration>
<property name="log.path" value="/home/root/ruoyi/logs" />
<property name="log.pattern" value="%d{yyyy-mm-dd hh:mm:ss.sss} [%thread] %-5level %logger - [%method,%line] %x{dd.service} %x{dd.trace_id} %x{dd.span_id} - %msg%n" />
<appender name="console" class="ch.qos.logback.core.consoleappender">
<encoder>
<pattern>${log.pattern}</pattern>
</encoder>
</appender>
<appender name="file_info" class="ch.qos.logback.core.rolling.rollingfileappender">
<file>${log.path}/sys-info.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.timebasedrollingpolicy">
<filenamePattern>${log.path}/sys-info.%d{yyyy-mm-dd}.log</filenamePattern>
<maxHistory>60</maxHistory>
</rollingpolicy>
<encoder>
<pattern>${log.pattern}</pattern>
</encoder>
</appender>
</configuration>
upstream tomcat_servers {
server 192.168.1.1:8080;
server 192.168.1.2:8080;
}
server {
listen 80;
location / {
proxy_pass http://tomcat_servers;
}
}
通過遵循上述最佳實踐,可以在Debian系統上高效、安全地部署和管理Tomcat應用。