Logrotate is the default and easiest log management tool around. It is shipped by default with most of the major Linux distributions. Logrotate can help you to rotate logs (in other words, it can create a separate log file per day/week/month/year or on the basis of size of log file). It can compress the older log files. It can run custom scripts after rotation. It can rename the log to reflect the date.
Logrotate scripts goes to /etc/logrotate.d/. Let us see some examples to understand it better. Here we’ll rotate /var/log/anyapp.log
1. Rotate logs daily:
$ cat /etc/logrotate.d/anyapp
/var/log/anyapp.log {
daily
rotate 7
}
The logrotate script above will rotate /var/log/anyapp.log everyday and it’ll keep the last 7 rotated log Files To Other Machines On The Local Network [Linux, Windows] » href= »http://www.adminreseau.fr/nitroshare-easily-send-files-to-other-machines-on-the-local-network-linux-windows/ »>files. Instead of daily you can use monthly or weekly also.
2. Compress the rotated logs:
$ cat /etc/logrotate.d/anyapp
/var/log/anyapp.log {
daily
rotate 7
compress
}
Now you’ll find that logrotate is also compressing the rotated files. This is really a big life saver if you want to save some disk space which is a very common use case specially in VPS or cloud environment.
By default logrotate does a gzip compression. You can alter this behavior by using compresscmd. For example « compresscmd /bin/bzip2 » will get you bzip2 compression.
3. Compress in the next cycle:
$ cat /etc/logrotate.d/anyapp
/var/log/anyapp.log {
daily
rotate 7
compress
delaycompress
}
This is useful in case it is not possible to immediately compress the file. This happens when the process keeps on writing to the old file even after the rotation. If the last line sounded strange to you then you Unity 2D Might Go Away, Released With Improved UI, More [PPA] » href= »http://www.adminreseau.fr/audacious-3-3-alpha-1-released-with-improved-ui-more-ppa/ »>More [Ubuntu 12.10] » href= »http://www.adminreseau.fr/uds-q-news-unity-2d-might-go-away-more-ubuntu-12-10/ »>might want to read about inodes. Also note that « delaycompress » will work only if « compress » is included in the script.
4. Compressing the copy of the log:
$ cat /etc/logrotate.d/anyapp
/var/log/anyapp.log {
daily
rotate 7
compress
delaycompress
copytruncate
}
Copytruncate comes handy in the situation where process writes to the inode of the log and rotating the log might cause process to go defunct or stop logging or a bunch of other issues. Copytruncate copies the log and the further processing is done on the copy. It also truncates the original file to zero bytes. Therefore the inode of the file is unchanged and process keeps on writing to the log file as if nothing has happened.
5. Don’t rotate empty log and don’t give error if there is no log:
$ cat /etc/logrotate.d/anyapp
/var/log/anyapp.log {
daily
rotate 7
compress
delaycompress
copytruncate
notifempty
missingok
}
Self explanatory. Both « notifempty » and « missingok » has opposite twins named « ifempty » and « nomissingok » which are the defaults for logrotate.
6. Execute custom script before and/or after logrotation:
$ cat /etc/logrotate.d/anyapp
/var/log/anyapp.log {
daily
rotate 7
prerotate
/bin/myprescript.sh
endscript
postscript
Recent Comments