在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日志的轮转。