Tomcat通常以專用用戶(如tomcat)運行,避免使用root。通過以下命令查看啟動用戶:
ps -ef | grep tomcat
若用戶為root,需修改為tomcat(需提前創建該用戶,參考)。
Tomcat日志默認存放在$CATALINA_HOME/logs(如/opt/tomcat/logs),需確保tomcat用戶對其有讀寫權限:
sudo chown -R tomcat:tomcat /opt/tomcat/logs
sudo chmod -R 755 /opt/tomcat/logs # 目錄權限設為755(所有者可讀寫執行,其他用戶可讀執行)
catalina.out):sudo chown tomcat:tomcat /opt/tomcat/logs/catalina.out
sudo chmod 644 /opt/tomcat/logs/catalina.out # 文件權限設為644(所有者可讀寫,其他用戶可讀)
Tomcat啟動時會重置UMASK,若UMASK值為0027(默認),生成的日志文件權限為640(僅所有者可寫),導致其他用戶無法讀取。需修改catalina.sh(位于$CATALINA_HOME/bin):
sudo vi /opt/tomcat/bin/catalina.sh
找到umask相關行(通常在腳本開頭),將umask 0027改為umask 0022(對應權限644),保存后重啟Tomcat:
sudo systemctl restart tomcat
使用logrotate工具自動輪換日志,避免日志文件過大且權限混亂。創建/etc/logrotate.d/tomcat文件,添加以下內容:
/opt/tomcat/logs/catalina.out {
daily # 每日輪換
rotate 7 # 保留7份舊日志
compress # 壓縮舊日志(如catalina.out.1.gz)
delaycompress # 延遲壓縮(避免立即壓縮導致權限問題)
missingok # 若日志不存在也不報錯
notifempty # 若日志為空則不輪換
create 640 tomcat tomcat # 輪換后創建的新日志權限為640,所有者為tomcat
postrotate # 輪換后執行的命令(通知Tomcat重新打開日志文件)
/bin/kill -HUP `cat /var/run/tomcat.pid` 2>/dev/null || true
endscript
}
保存后,logrotate會按配置自動管理日志權限。
若使用Log4j2或Logback等框架,可在配置文件中直接指定日志文件的權限:
log4j2.xml):<File name="File" fileName="logs/catalina.log">
<filePermissions>rw-r--r--</filePermissions> <!-- 對應644權限 -->
</File>
logback.xml):<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<file>logs/catalina.log</file>
<prudent>false</prudent>
<append>true</append>
<filePermissions>644</filePermissions> <!-- 直接設置權限 -->
</appender>
ls -l /opt/tomcat/logs/
輸出應類似:-rw-r--r-- 1 tomcat tomcat 1024 Sep 20 10:00 catalina.out
catalina.out是否有新內容且權限正確。通過以上步驟,可解決CentOS下Tomcat日志的權限問題,確保日志文件可被正確訪問和管理。