Tomcat localhost_access_log files cleanup

2019-04-09 17:28发布

We have Solr running on Tomcat 8. We are having issues in our different environments with localhost_access_log files filling up the servers. These files are created by the Access Valve Log in server.xml configured like this -

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
   prefix="localhost_access_log" 
   suffix=".txt" pattern="%h %l %u %t &quot;%r&quot; %s %b" />

From what I've read, there is no OOTB way in Tomcat to clean up old log files. What can I implement to clean up the old access log files?

2条回答
\"骚年 ilove
2楼-- · 2019-04-09 18:15

You can disable localhost_access log by commenting configuration line.

or

In linux, set daily cron job to delete old files.

0 0 * * * /path/to/your/script/cleanup.sh

cleanup.sh

#This will remove files older than a week.
find /TOMCAT_HOME/logs -name "localhost_access_log*.txt" -type f -mtime +7 -exec rm -f {} \;
查看更多
对你真心纯属浪费
3楼-- · 2019-04-09 18:17

You can have a log rotation and then choose what logs files to delete

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log" suffix=".txt" rotatable="true" renameOnRotate="true" pattern="%h %l %u %t &quot;%r&quot; %s %b" />

As rotation is set to true by default you should already have it. Then you can for exemple delete logs older than 5 days:

To delete log files older than 10 days the following commands can be used.

Unix
find /path/to/httplogs/ -name "*.log" -type f -mtime +10 -exec rm -f {} \;

For Windows Server OS:
forfiles /p "C:\path\to\httplogs" /s /m *.log /d -10 /c "cmd /c del @PATH"
查看更多
登录 后发表回答