Как автоматически очистить журналы с отметками даты

У меня есть веб-сервер Apache с различными виртуальными хостами. Каждый виртуальный хост регистрирует файлы с датой, используя cronolog. В результате я получаю много таких файлов:

----rw-r-- 1 root     root      467894 2013-02-01 13:43 2013-02-01-tracg.dev.local-access.log
----rw-r-- 1 root     root         222 2013-02-01 01:09 2013-02-01-tracg.dev.local-error.log
----rw-r-- 1 root     root         222 2013-02-02 01:10 2013-02-02-tracg.dev.local-error.log
----rw-r-- 1 root     root         333 2013-02-03 06:47 2013-02-03-tracg.dev.local-error.log
-rw-r--r-- 1 root     root       39574 2013-02-04 14:20 2013-02-04-tracg.dev.local-access.log
----rw-r-- 1 root     root         444 2013-02-04 08:24 2013-02-04-tracg.dev.local-error.log
----rw-r-- 1 root     root         444 2013-02-05 12:14 2013-02-05-tracg.dev.local-error.log
----rw-r-- 1 root     root       98135 2013-02-06 13:30 2013-02-06-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-06 09:13 2013-02-06-tracg.dev.local-error.log
-rw-r--r-- 1 root     root        8872 2013-02-07 13:55 2013-02-07-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-07 02:00 2013-02-07-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         666 2013-02-08 14:31 2013-02-08-tracg.dev.local-error.log
----rw-r-- 1 root     root         192 2013-02-09 01:08 2013-02-09-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         530 2013-02-09 01:08 2013-02-09-tracg.dev.local-error.log
----rw-r-- 1 root     root         192 2013-02-10 01:08 2013-02-10-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         641 2013-02-10 06:32 2013-02-10-tracg.dev.local-error.log
----rw-r-- 1 root     root       64565 2013-02-11 13:56 2013-02-11-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         752 2013-02-11 06:28 2013-02-11-tracg.dev.local-error.log
----rw-r-- 1 root     root       54988 2013-02-12 11:56 2013-02-12-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         752 2013-02-12 08:45 2013-02-12-tracg.dev.local-error.log
-rw-r--r-- 1 root     root       15003 2013-02-13 11:19 2013-02-13-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-13 10:48 2013-02-13-tracg.dev.local-error.log
----rw-r-- 1 root     root       32819 2013-02-14 15:43 2013-02-14-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-14 14:29 2013-02-14-tracg.dev.local-error.log
----rw-r-- 1 root     root      135665 2013-02-15 13:53 2013-02-15-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-15 11:39 2013-02-15-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         444 2013-02-16 01:10 2013-02-16-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         555 2013-02-17 06:33 2013-02-17-tracg.dev.local-error.log
-rw-r--r-- 1 root     root       30763 2013-02-18 14:15 2013-02-18-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-18 09:00 2013-02-18-tracg.dev.local-error.log
----rw-r-- 1 root     root       15058 2013-02-19 09:37 2013-02-19-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-19 09:16 2013-02-19-tracg.dev.local-error.log
----rw-r-- 1 root     root      132587 2013-02-20 15:55 2013-02-20-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         444 2013-02-20 01:11 2013-02-20-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         666 2013-02-21 09:07 2013-02-21-tracg.dev.local-error.log
-rw-r--r-- 1 root     root      226997 2013-02-22 15:36 2013-02-22-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-22 08:26 2013-02-22-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         444 2013-02-23 01:12 2013-02-23-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         555 2013-02-24 06:48 2013-02-24-tracg.dev.local-error.log
----rw-r-- 1 root     root      130913 2013-02-25 11:36 2013-02-25-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-25 11:37 2013-02-25-tracg.dev.local-error.log
----rw-r-- 1 root     root       21542 2013-02-26 14:43 2013-02-26-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-26 15:39 2013-02-26-tracg.dev.local-error.log
----rw-r-- 1 root     root       99698 2013-02-27 13:28 2013-02-27-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         444 2013-02-27 01:13 2013-02-27-tracg.dev.local-error.log
----rw-r-- 1 root     root      111632 2013-02-28 13:57 2013-02-28-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-02-28 11:55 2013-02-28-tracg.dev.local-error.log
----rw-r-- 1 root     root      205731 2013-03-01 13:30 2013-03-01-tracg.dev.local-access.log
-rw-r--r-- 1 root     root        1332 2013-03-01 14:31 2013-03-01-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         444 2013-03-02 01:11 2013-03-02-tracg.dev.local-error.log
-rw-r--r-- 1 root     root         555 2013-03-03 06:35 2013-03-03-tracg.dev.local-error.log
----rw-r-- 1 root     root      211616 2013-03-04 10:42 2013-03-04-tracg.dev.local-access.log
-rw-r--r-- 1 root     root         666 2013-03-04 10:42 2013-03-04-tracg.dev.local-error.log

Это все хорошо, однако, я хотел бы, чтобы cron автоматически распаковывал все файлы журнала, которые в данный момент не используются. Я не могу просто сделать: gzip -9 / data / www / virtual // log /.log

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

4 ответа

Решение

Одним из способов будет:

find /data/www/virtual/log/ -name '*.log' -mtime +2 -exec gzip {} +

Это сжимает любой файл, который заканчивается .log это не было изменено в течение по крайней мере двух дней.

Другой способ будет:

gzip $(date --date="yesterday" "+/data/www/virtual/log/%Y-%m-*.log")

Это вычисляет вчерашнюю дату и сжимает любые файлы, которые начинаются с этой даты и заканчиваются в .log,

Имейте в виду, что $() а также % не будет работать в Cron, потому что $() это вещь бэша и % имеет особое значение в crontabs. Поместите это в скрипт и вызовите скрипт из задания cron. На самом деле, сделайте это для всех этих методов.

Еще один способ:

for FILE in /data/www/virtual/log/*.log
do
  if [ `fuser -s $FILE` ]
  then
    gzip $FILE
  fi
done

Это сжимает любые файлы, которые заканчиваются .log и в настоящее время не открыты каким-либо процессом.

Может быть возможно настроить logrotate чтобы справиться с этим для вас, все еще используя cronolog, Я никогда не использовал logrotate с файлами журналов, которые имеют разные имена каждый день, но вы можете указать *.log в файлах конфигурации, так что это может быть возможно.

В качестве альтернативы, вы можете просто бросить cronolog, войти в тот же файл все время и иметь logrotate перемещайте их каждый день. Это также будет обрабатывать удаление самых старых, так что у вас будет относительно стабильный объем используемого дискового пространства.

Пытаться:

ls -d /path/to/[0-9]*tracg.dev.local-*.log | sort -r | sed '1,2d' | xargs gzip -9

Это будет быстрее, чем проверка каждого файла на открытость, но при этом предполагается, что первые два в списке (отсортированные в обратном порядке в алфавитном порядке; последние два будут сверху) - это те, которые вы хотите пропустить.

[Команда sed удаляет строки 1-2 ]

Logrotate принимает подстановочные знаки в файле man "man logrotate" есть пример подстановочного знака для демона usenet INN:

   /var/log/news/* {
       monthly
       rotate 2
       olddir /var/log/news/old
       missingok
       postrotate
           kill -HUP ‘cat /var/run/inn.pid‘
       endscript
       nocompress
   }

надеюсь, это поможет

Пример сценария Bash для перемещения старых файлов журнала:

logdir='/data/www/virtual//log/'
year=`date +%Y`
touch -t `date +%m%d0000` /tmp/tdate
            for i in $(find $logdir -maxdepth 1 -type f ! -newer /tmp/tdate)
                    do
                            month=`ls -al $i | awk '{print $6}'`
                            day=`ls -al $i | awk '{print $7}'`
                            ls -al $i | awk '{print $8}' | grep ":" > /dev/null
                            if [ $? = 0 ]
                                    then
                                            mkdir -p $logdir/previous/$day-$month-$year
                                            mv $i $logdir/previous/$day-$month-$year
                                    else
                                            year1=`ls -al $i | awk '{print $8}'`
                                            mkdir -p $logdir/previous/$day-$month-$year1
                                            mv $i $logdir/previous/$day-$month-$year1
                            fi
                    done
    rm -rf /tmp/tdate

Создайте предыдущий каталог в каталоге / data / www / virtual // log /. Все журналы старше сегодняшней даты будут перемещены в предыдущий каталог. Внутри предыдущего каталога он снова создаст каталоги, а файлы журналов будут находиться в каталогах с датой, к которой они принадлежали.

Или простое решение, используйте Logrotate

Другие вопросы по тегам