Привет, делаю скриптец который разбирает файл построчно, там если функция которая реализует "tail -f", но вот затыка в том что ночью файлы ротейтятся, и дескриптор, читаемый файл подменяется, а скрипт продолжает читать информацию по дескриптору из старого файла, в который ничего уже не пишется. Подскажите как переделать функции, не могу додумать что проверять в цикле текующую позицию или брать каждый раз статистику о файле или время его создания?Пожалуйста не предлагайте использовать класс типо "filetail.py" и пр., хотелось бы реализовать коротко и просто в своем скрипте, без левых "нестандартных классов", которые не идут в redhat "из коробки".
#Set the filename and open the file
filename = 'security_log'
file = open(filename,'r')#Find the size of the file and move to the end
st_results = os.stat(filename)
st_size = st_results[6]
file.seek(st_size)while 1:
where = file.tell()
line = file.readline()
if not line:
time.sleep(1)
file.seek(where)
else:
print line # и дальше
Держать файл всегда открытым сторонним скриптом не очень хорошо
Не лучше ли считывать по-минутно только последние записи?А так - в logrotate есть опция "truncate" - это можно использовать для вашего случая
файл копируется, и потом все записи стираются, но сам дескриптор остается прежним.
> Держать файл всегда открытым сторонним скриптом не очень хорошо
> Не лучше ли считывать по-минутно только последние записи?
> А так - в logrotate есть опция "truncate" - это можно использовать
> для вашего случая
> файл копируется, и потом все записи стираются, но сам дескриптор остается прежним.Спасибо за совет, действительно держать лишний лок на файле плохая идея, т.е лучше делать в цикле открыть/читать/закрыть/ждать , запоминая последнюю позицию?
Поминутно достаточно редко, нужен реалтайм или очень близко к этому.
А если коневеером пихать вместо logrotate в твой скрипт, а затем уже вываливать в logrotate?log | script | logrotate
> Привет, делаю скриптец который разбирает файл построчно, там если функция которая реализует
> "tail -f", но вот затыка в том что ночью файлы ротейтятся,man tail
tail -F> и дескриптор, читаемый файл подменяется, а скрипт продолжает читать информацию по
Про "скриптец" ничего не скажу.
>> Привет, делаю скриптец который разбирает файл построчно, там если функция которая реализует
>> "tail -f", но вот затыка в том что ночью файлы ротейтятся,
> man tail
> tail -F
>> и дескриптор, читаемый файл подменяется, а скрипт продолжает читать информацию по
> Про "скриптец" ничего не скажу.Как бы сабж про реализацию "tail -f" в питоне, кэп.
>> Про "скриптец" ничего не скажу.
> Как бы сабж про реализацию "tail -f" в питоне, кэп.Ой, а я и не понял. Так бы дёргал stat()-ом номер айнода файла и при изменении переоткрывал поимени, но ведь Пииииитон!!! же ж. Бьюсь ап стену в тупом бессилии.
>>> Про "скриптец" ничего не скажу.
>> Как бы сабж про реализацию "tail -f" в питоне, кэп.
> Ой, а я и не понял. Так бы дёргал stat()-ом номер айнода
> файла и при изменении переоткрывал поимени, но ведь Пииииитон!!! же ж.
> Бьюсь ап стену в тупом бессилии.Ну реализовал похоже немного, дергаю fstat время создания файла, и если файл по дескриптору старше, чем файл провереный по имени, то ...