syslog 회전

syslog 회전

나는 syslog c 인터페이스를 사용하여 메시지를 쓰는 작은 c 앱을 작성했습니다(man 3 syslog에서):

void openlog(const char *ident, int logopt, int facility);
void syslog(int priority, const char *message, ...);
void closelog(void);

내 질문: 에서 LOCAL0에 메시지를 쓰고 있습니다 /var/log/local0.log. 또한 logrotate를 호출하는 cron도 있습니다 /var/log/local0.log. 회전 후에 내 앱이 새 /var/log/local0.log.

후회전 스크립트로 이 문제를 해결하는 가장 좋은 방법은 무엇입니까?

  1. 쉽지만 이상적이지는 않습니다. rsyslog 데몬을 완전히 다시 시작하세요.

  2. 내 앱에서 SIGHUP을 보내고 처리합니다. 이것이 가장 적절한 해결책인 것 같습니다. 하지만 HUP를 받으면 무엇을 해야 할지 잘 모르겠습니다. closelog()를 호출한 다음 openlog()를 호출하면 됩니까?

답변1

상황에 맞지 않지만 "긴급"에 사용할 수 있는 또 다른 괜찮은 해결 방법은 logrotate의 copytruncate 옵션입니다. 이는 로그 파일에 기록되는 모든 내용에 대해 알릴 필요가 없음을 의미합니다.

관련 정보