Как удалить старые логи с помощью launchd / launchctl - PullRequest
0 голосов
/ 26 марта 2020

У меня есть эта конфигурация запуска:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
         <key>Label</key>
         <string>org.ores.cprev</string>
         <key>Program</key>
         <string>/Users/alex/.local/bin/cprev-safe-start</string>
         <key>ProgramArguments</key>
         <array>
          <string>/Users/alex/.local/bin/cprev-safe-start</string>
          <string>--foo</string>
         </array>
         <key>RunAtLoad</key>
          <true/>
         <key>KeepAlive</key>
          <dict>
              <key>SuccessfulExit</key>
              <true/>
          </dict>
          <key>StandardErrorPath</key>
          <string>/tmp/cprev.stderr.log</string>
          <key>StandardOutPath</key>
          <string>/tmp/cprev.stdout.log</string>
</dict>
</plist>

Меня беспокоит, что журналы по адресу:

      <key>StandardErrorPath</key>
      <string>/tmp/cprev.stderr.log</string>
      <key>StandardOutPath</key>
      <string>/tmp/cprev.stdout.log</string>

со временем будут заполняться и увеличиваться в размере на диске. , Есть ли способ автоматического удаления старых строк или простой ротации журналов?

может быть что-то вроде:

my_proc > >(tail -f -n 50 /tmp/cprev.stdout.log > /tmp/cprev.stdout.log)

с использованием подстановки процесса сохраняются только 50 последних строк в файле ? конечно, это может привести к бесконечному l oop ..

, поэтому вместо этого может быть фоновый процесс, который делает это:

 inotifywait -m -e modify /tmp/cprev.stdout.log | 
      tail -n 500 > /tmp/cprev.stdout.log

, который потенциально будет бесконечно l oop, так что, может быть, это:

while true; do
   inotifywait -e modify /tmp/cprev.stdout.log |
      tail -n 500 /tmp/cprev.stdout.log > /tmp/cprev.stdout.log
done;

, что кажется дорогим, переписывая файл каждый раз, когда он записывается. плюс нужно вручную поддерживать этот отдельный процесс.

...