溫馨提示×

如何設置Ubuntu Tomcat日志輪轉

小樊
46
2025-05-11 09:08:52
欄目: 智能運維

在Ubuntu系統中,Tomcat的日志輪轉可以通過配置logrotate工具來實現。以下是詳細的步驟:

1. 安裝logrotate

首先,確保你的系統上已經安裝了logrotate。如果沒有安裝,可以使用以下命令進行安裝:

sudo apt-get update
sudo apt-get install logrotate

2. 創建或編輯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腳本。
  • postrotateendscript: 在輪轉日志后執行的腳本,這里用于重啟Tomcat服務。

3. 測試配置

保存并關閉文件后,你可以手動測試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

4. 設置定時任務

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日志的輪轉。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女