Рейтинг:0

Logrotate не записывает в новый файл .log

флаг jp

У меня есть 4 пользовательских сервиса systemd, которые пишут в пользовательские журналы. /вар/журнал/. я создал logrotate config, но он не записывает в новейший журнал. Он все еще пишет на старом .log.1 файл. Новые созданный, просто нет данных.

Вот моя конфигурация logrotate:

/var/log/дилер*.log {
        ежедневно
        отсутствует
        повернуть 7
        задержка сжатия
        непустой
        су корень корень
        постротировать
        /bin/systemctl перезагрузить дилера*.service > /dev/null 2>/dev/null || истинный
        эндскрипт
        создать 0644 корень корень

}

Самые новые файлы журналов пусты:

-rw-r--r-- 1 root root 0 июль 12 11:39 дилерF2f.log
-rw-r--r-- 1 root root 0 12 июля 11:39 дилерOutbound.log
-rw-r--r-- 1 root root 0 12 июля 11:39 дилерTimeout.log
-rw-r--r-- 1 root root 0 июль 12 11:39 дилерWeb.log

Он до сих пор пишет в .log.1:

-rw-r--r-- 1 root root 36M 12 июля 12:52 дилерOutbound.log.1
-rw-r--r-- 1 root root 9.2M 12 июл 12:52 дилерF2f.log.1
-rw-r--r-- 1 root root 19M 12 июля 12:52 дилерWeb.log.1
-rw-r--r-- 1 root root 171M 12 июля 12:52 дилерTimeout.log.1
Рейтинг:0
флаг it

Обычно я вижу что-то подобное, когда процесс все еще имеет открытый файл — он будет продолжать писать в старый файл, пока процесс не будет перезапущен.

Могу поспорить, что если вы сделаете перезагрузку вместо перезагрузки, все будет работать как положено.

Если вы не можете перезапустить процесс полностью, посмотрите на опцию copytruncate вместо сценария postrotate.

копироватьусечение Сократите исходный файл журнала до нулевого размера после создания копии вместо перемещения старого файла журнала и, при необходимости, создание нового. Его можно использовать, когда какой-либо программе нельзя сказать закрыть свой файл журнала, и поэтому она может продолжить запись. (добавление) к предыдущему файлу журнала навсегда. Обратите внимание, что между копированием файла и запуском проходит очень небольшой промежуток времени. , поэтому некоторые данные регистрации могут быть потеряны. При использовании этой опции опция создания не будет иметь никакого эффекта, так как старая лог-файл остается на месте.

DevOpsSauce avatar
флаг jp
Я пытаюсь избежать полного перезапуска, поскольку мой `ExecStopPost` вызывает сценарий bash, который отправляет электронное письмо, однако использование copytruncate и удаление раздела postrotate сделали то, что мне нужно. Он создал новый журнал и начал правильно писать в него. Большое тебе спасибо.
Ginnungagap avatar
флаг gu
`copytruncate` — это крайняя мера, так как его дизайн несовершенен (потому что это лучшее, что можно сделать с учетом требований). Службы действительно должны быть способны правильно поддерживать ротацию файлов журналов.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.