Subject: The mailing list for listmasters using Sympa
List archive
- From: Steve Shipway <address@concealed>
- To: Sean Hennessee <address@concealed>, "address@concealed" <address@concealed>
- Subject: RE: [sympa-users] Sympa log file handling?
- Date: Wed, 9 Oct 2013 19:29:03 +0000
Using logrotate on sympa log files.
The problem here is that logrotate normally works by renaming the old file
and creating a new one. However, if the application (sympa, in this case)
does a single open of a file descriptor for the logging file, then this FD
will continue to point to the old file, until (for some reason) it does a
reopen. Hence, the new file has length 0 and the oldfile continues to grow.
To get around this, logrotate has a couple of options. Firstly, it can
perform actions after the rotate - such as sending a SIGHUP to the relevant
daemon, so that it knows it is time to re-open the log files. This method is
used for many daemons; if you have a PID file for sympa, then you can add a
post rotate script to do a "kill -HUP `cat $pidfile`".
Unfortunately, not all applications will catch SIGHUP and trigger a log file
re-opening. In particular, sympa uses SIGHUP to indicate a request to stop
detailed logging so this is no use.
What you can do, is to have a postrotate action of "/etc/init.d/sympa
restart". However this can be problematic with a large list server, which
takes longer to shut down the sympa.pl process, so you might instead like to
do this:
postrotate
/etc/init.d/sympa stop
sleep 30
/etc/init.d/sympa start
endscript
You can adjust the sleep time for whatever works for you. Of course, your
list server is inactive during the rotate, but this is unlikely to be
problematic unless you have a seriously high throughput... (We use this
method).
The second option you have is using copytruncate. This makes logrotate copy
the log file and truncate the old one, instead of renaming and creating a new
one. This means that the sympa process can keep its FD open to the file
without having to restart. However, there is a small race condition that
means you may lose a log entry between the copy and the truncate actions;
also, there is a chance that for some reason the append doesnt combine with
the truncate correctly, so you should test it out first.
The best solution can only be done by the Sympa development team - have sympa
respond to a signal (SIGUSR1?) by re-opening its log files, allowing a smooth
transition by logrotate.
Steve
Steve Shipway
University of Auckland ITS
UNIX Systems Design Lead
address@concealed
Ph: +64 9 373 7599 ext 86487
-
[sympa-users] Sympa log file handling?,
Sean Hennessee, 10/09/2013
-
RE: [sympa-users] Sympa log file handling?,
Steve Shipway, 10/09/2013
-
Re: [sympa-users] Sympa log file handling?,
Sean Hennessee, 10/09/2013
-
RE: [sympa-users] Sympa log file handling?,
Steve Shipway, 10/09/2013
- Re: [sympa-users] Sympa log file handling?, Sean Hennessee, 10/09/2013
-
RE: [sympa-users] Sympa log file handling?,
Steve Shipway, 10/09/2013
-
Re: [sympa-users] Sympa log file handling?,
Sean Hennessee, 10/09/2013
-
RE: [sympa-users] Sympa log file handling?,
Steve Shipway, 10/09/2013
Archive powered by MHonArc 2.6.19+.