running newsyslog fiveminly

Eugene Grosbein egrosbein at rdtc.ru
Sun Jul 31 17:56:46 UTC 2011


01.08.2011 00:31, Jeremy Chadwick writes:

>> For second kind of logs we have lines in newsyslog.conf such as following:
>>
>> /var/log/mpd.log 640 16 * @T0000  JC
>>
>> This must ensure that /var/log/mpd.log is rotated and compressed at midnigt only.
>> Note, that compressing the file takes 8 minutes.
   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

> I have three things to say on the matter, all of which are somewhat

Five things really :-)

> independent of one another so please keep that in mind.  I imagine #1
> below is your problem.
> 
> 1) The newsyslog.conf(5) man page has this clause in it, for the "when"
> field (in your case, @T0000):
> 
>      when    ...  If the when field contains an asterisk (`*'), log rotation
>              will solely depend on the contents of the size field.  Otherwise,
>              the when field consists of an optional interval in hours, usually
>              followed by an `@'-sign and a time in restricted ISO 8601 format.
> 
>              If a time is specified, the log file will only be trimmed if
>              newsyslog(8) is run within one hour of the specified time.  If an
>              interval is specified, the log file will be trimmed if that many
>              hours have passed since the last rotation. ...
> 
> You might think that "one hour of the specified time" value/clause
> correlates with the interval that newsyslog is run at via cron, but that
> would be wrong.  newsyslog REALLY DOES have hard-coded values for 3600
> seconds (1 hour) in it (grep -r 3600 /usr/src/usr.sbin/newsyslog).  I
> have not looked at the code, but the fact of the matter is, 1 hour
> appears to be a "special" value.  I would heed that as a warning.
> 
> 2) Are you absolutely sure mpd.log is being rotated AND compressed within
> the 5 minute window?  If mpd.log is extremely large and your disks are
> slow, this could take a long time.  If possible, try (temporarily)
> removing bzip2 from the picture (remove J flag).

I've noted (see above) that compression takes 8 minutes.
I just think newsyslog should not deal with the file at 00:05.

> 3) mpd(8) logs via syslog(3).  When newsyslog(8), are you aware that it
> sends a SIGHUP to syslogd(8)?  As such, are you absolutely certain when
> this happen (every 5 minutes!) that the new log files are getting
> created correctly and promptly?

I see no other problems.

> 4) To debug this, you're probably going to need to run some cronjobs or
> daemons that keep a very close eye on /var/log/mpd.log* when the log
> rotation runs, in combination with running syslogd(8) in debug mode
> and/or verbose mode.

syslogd or newsyslo needs debug mode?

> 5) Why do you need to rotate logs every 5 minutes?  Why do you need such
> extreme levels of granularity in your rotated logs?  Just how much data
> are you logging via syslog?  If a lot, why so much?  It might be more
> effective to consider expanding your logging infrastructure to multiple
> machines if this the case.

Most of my boxes are diskless NanoBSD installations having /var in memory
and I need very detailed debug logs that grow quickly. These logs
can easily overflow /var partition in case of network problems (storms etc.)
so newsyslog have to check them often.

And I have another router that has an HDD to keep daily log and I'd like
to have their crontabs unified.

Eugene Grosbein



More information about the freebsd-stable mailing list