在Ubuntu系統中,Tomcat的日志輪轉可以通過配置logrotate
工具來實現。以下是詳細的步驟:
logrotate
首先,確保你的系統上已經安裝了logrotate
。如果沒有安裝,可以使用以下命令進行安裝:
sudo apt-get update
sudo apt-get install logrotate
logrotate
配置文件Tomcat的日志文件通常位于/var/log/tomcatX/
目錄下,其中X
是Tomcat的版本號。你需要為每個Tomcat實例創建一個單獨的配置文件。
例如,如果你的Tomcat實例位于/var/log/tomcat9/
,你可以創建一個名為tomcat9
的配置文件:
sudo nano /etc/logrotate.d/tomcat9
在打開的文件中,添加以下內容:
/var/log/tomcat9/*.log {
daily
missingok
rotate 7
compress
notifempty
create 640 root adm
sharedscripts
postrotate
if [ -f /var/run/tomcat9.pid ]; then
/usr/share/tomcat9/bin/shutdown.sh
fi
sleep 5
/usr/share/tomcat9/bin/startup.sh
endscript
}
解釋一下這些選項:
daily
: 每天輪轉日志。missingok
: 如果日志文件不存在,不會報錯。rotate 7
: 保留7個輪轉的日志文件。compress
: 壓縮舊的日志文件。notifempty
: 如果日志文件為空,不進行輪轉。create 640 root adm
: 創建新的日志文件,權限為640,屬主為root,屬組為adm。sharedscripts
: 如果有多個日志文件匹配,只執行一次postrotate腳本。postrotate
和 endscript
: 在輪轉日志后執行的腳本,這里用于重啟Tomcat服務。保存并關閉文件后,你可以手動測試logrotate
配置是否正確:
sudo logrotate -f /etc/logrotate.d/tomcat9
如果一切正常,你應該會看到類似以下的輸出:
reading config file /etc/logrotate.d/tomcat9
...
rotating pattern: /var/log/tomcat9/*.log daily (7 rotations)
empty log files are not rotated, old versions are removed
considering log /var/log/tomcat9/catalina.out
...
rotating archive: /var/log/tomcat9/catalina.out.1.gz, log->rotateCount = 7, rotateSize = 0
dateext suffix '-2023-04-10'
glob pattern '-[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]'
renaming /var/log/tomcat9/catalina.out.1.gz to /var/log/tomcat9/catalina.out.2.gz (rotatecount 7, logstart 1, i 8)
renaming /var/log/tomcat9/catalina.out.2.gz to /var/log/tomcat9/catalina.out.3.gz (rotatecount 7, logstart 1, i 7)
...
renaming /var/log/tomcat9/catalina.out.7.gz to /var/log/tomcat9/catalina.out.8.gz (rotatecount 7, logstart 1, i 1)
renaming /var/log/tomcat9/catalina.out.8.gz to /var/log/tomcat9/catalina.out (rotatecount 7, logstart 1, i 0)
copying /var/log/tomcat9/catalina.out to /var/log/tomcat9/catalina.out.1
copying /var/log/tomcat9/localhost.<date>.log to /var/log/tomcat9/localhost.<date>.log.1
copying /var/log/tomcat9/manager.<date>.log to /var/log/tomcat9/manager.<date>.log.1
copying /var/log/tomcat9/host-manager.<date>.log to /var/log/tomcat9/host-manager.<date>.log.1
copying /var/log/tomcat9/localhost_access_log.<date>.txt to /var/log/tomcat9/localhost_access_log.<date>.txt.1
copying /var/log/tomcat9/access_log.<date>.txt to /var/log/tomcat9/access_log.<date>.txt.1
copying /var/log/tomcat9/solr.log to /var/log/tomcat9/solr.log.1
copying /var/log/tomcat9/localhost.<date>.log to /var/log/tomcat9/localhost.<date>.log.1
copying /var/log/tomcat9/manager.<date>.log to /var/log/tomcat9/manager.<date>.log.1
copying /var/log/tomcat9/host-manager.<date>.log to /var/log/tomcat9/host-manager.<date>.log.1
copying /var/log/tomcat9/localhost_access_log.<date>.txt to /var/log/tomcat9/localhost_access_log.<date>.txt.1
copying /var/log/tomcat9/access_log.<date>.txt to /var/log/tomcat9/access_log.<date>.txt.1
copying /var/log/tomcat9/solr.log to /var/log/tomcat9/solr.log.1
dateext suffix '-2023-04-10'
glob pattern '-[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]'
renaming /var/log/tomcat9/catalina.out.1.gz to /var/log/tomcat9/catalina.out.2.gz (rotatecount 7, logstart 1, i 8)
renaming /var/log/tomcat9/catalina.out.2.gz to /var/log/tomcat9/catalina.out.3.gz (rotatecount 7, logstart 1, i 7)
...
renaming /var/log/tomcat9/catalina.out.7.gz to /var/log/tomcat9/catalina.out.8.gz (rotatecount 7, logstart 1, i 1)
renaming /var/log/tomcat9/catalina.out.8.gz to /var/log/tomcat9/catalina.out (rotatecount 7, logstart 1, i 0)
copying /var/log/tomcat9/catalina.out to /var/log/tomcat9/catalina.out.1
copying /var/log/tomcat9/localhost.<date>.log to /var/log/tomcat9/localhost.<date>.log.1
copying /var/log/tomcat9/manager.<date>.log to /var/log/tomcat9/manager.<date>.log.1
copying /var/log/tomcat9/host-manager.<date>.log to /var/log/tomcat9/host-manager.<date>.log.1
copying /var/log/tomcat9/localhost_access_log.<date>.txt to /var/log/tomcat9/localhost_access_log.<date>.txt.1
copying /var/log/tomcat9/access_log.<date>.txt to /var/log/tomcat9/access_log.<date>.txt.1
copying /var/log/tomcat9/solr.log to /var/log/tomcat9/solr.log.1
logrotate
默認每天運行一次。如果你需要更頻繁地運行,可以編輯/etc/logrotate.conf
文件,調整daily
為其他時間間隔,或者創建一個定時任務。
/etc/logrotate.conf
sudo nano /etc/logrotate.conf
找到并修改以下行:
daily
可以改為:
hourly
或者創建一個定時任務:
sudo crontab -e
添加以下行:
0 * * * * /usr/sbin/logrotate /etc/logrotate.conf
這會每小時運行一次logrotate
。
通過以上步驟,你應該能夠成功設置Ubuntu系統中Tomcat日志的輪轉。