LogRotate использовать регулярное выражение для имени файла
У меня есть собственный класс ведения журнала, который создает журнал для каждого экземпляра процесса и добавляет уникальный идентификатор к имени файла журнала, например:
- process.1234.log
- process.1235.log
Также я могу добавить отметку даты / времени, например:
- process.1234.03012012.log
- process.1235.03012012.log
Может ли LogRotate использовать регулярные выражения, чтобы я мог архивировать свои файлы журналов по дате и / или идентификатору процесса?
1 ответ
Я не знаю, есть ли более поздние версии, но после дальнейших исследований я обнаружил, что подстановочные знаки оболочки поддерживаются. И то и другое *
(соответствует нескольким символам) и ?
(соответствует одному символу) можно комбинировать для соответствия конкретным файлам.
В качестве примера, вот шаблоны, которые соответствуют вашему варианту использования вместе с остальной частью файла, который можно найти на /etc/logrotate.d/process
/path/to/my/logfiles/process.????.????????.log
/path/to/my/logfiles/process.????.log
{
# Look for previously matched log files and rotate daily if found
daily
# use date as a suffix of the rotated file
dateext
# Compress log file, optional if the files are small enough
compress
# Allow for a log file pattern to NOT match in order to support both
# filename formats
missingok
# Do not create replacement log files, the application will do that
nocreate
# Keep 30 days worth of rotated logs
maxage 30
}
Однако, если вы намеревались process
чтобы быть заполнителем для фактического идентификатора процесса, я полагаю, что вы можете избежать использования подстановочного знака вместо идентификатора процесса следующим образом:
/path/to/my/logfiles/*.????.????????.log
/path/to/my/logfiles/*.????.log
{
...
}
Надеюсь, это поможет. Я тоже отправился на поиски подходов регулярных выражений, которые бы сработали, и, наконец, решил использовать групповые символы оболочки вместо того, что, по моему мнению, было работоспособным, но более сложным решением.
Пример:
При поиске решения для регулярных выражений я обнаружил запись в блоге под названием " Исключение файлов из совпадений глобализации logrotate", которая предоставила это решение:
/var/log/upstart/*.log {
daily
missingok
rotate 7
compress
notifempty
nocreate
nosharedscripts
prerotate
bash -c "[[ ! $1 =~ testprogram ]]"
endscript
}
В итоге я вытащил две вещи из этого примера и немного изменил матч. В моей ситуации я хотел повернуть все файлы в каталоге, за исключением некоторых входных файлов, которые имеют .inp
расширение.
Вот что я придумал:
# Force the prerotate "script" below to be run on each individual file
# in order to verify that it isn't an unprocessed input file
nosharedscripts
# Skip rotating any unprocessed input files (*.inp extension)
prerotate
bash -c "[[ ! $1 =~ \.inp$ ]]"
endscript
В соответствии с logrotate -d /etc/logrotate.d/myfilename
похоже на работу. Однако, как я уже упоминал, я выбрал подход с использованием подстановочных знаков оболочки, так как кому-то, идущему за мной, было проще поддерживать.