[BUG] sendfile on; & output_buffers 1 128k;
Maxim Dounin
mdounin на mdounin.ru
Пн Сен 12 21:53:35 UTC 2011
Hello!
On Mon, Sep 12, 2011 at 08:06:36PM +0300, Андрей Василишин wrote:
>
> >А можно ещё для чистоты эксперимента патч откатить, и убедиться
> >что без патча проблема воспроизводится?
> >
> >Потому как я решительно не вижу причин, по которым данный патч мог
> >бы помочь.
> >
>
> В общем опять проблема воспроизвелась, при перемотке прыгает на
> начало (нгинкс тут без патча).
Судя по debug log'у, файл 110912-v.flv писали в процессе его
скачивания клиентами, в результате закешированная длина в
open_file_cache в разных рабочих процессах разная. Соответственно
если запрос со start=<много> попадал в рабочий процесс, считавший,
что длина файла меньше, в ответ отдавался полный файл.
В общем случае совет простой: не пишите файлы неатомарно, а если
пишите - будте готовы к сюрпризам.
В данном случае, судя по всему, ситуация усугублялась проблемой в
open_file_cache: после дописывания файла закешированный размер не
обновлялся. Прилагающийся патч проблему исправляет.
Maxim Dounin
-------------- next part --------------
# HG changeset patch
# User Maxim Dounin <mdounin at mdounin.ru>
# Date 1315864171 -14400
# Node ID 0786be1906af99a4ba20edeb8b24348ba6a88bef
# Parent 83b74d7020ba5d02b51f9e2e162bca943d47c486
Bugfix: open_file_cache did not update file info on retest.
If file inode was not changed, cached file information was not updated
on retest. As a result stale information might be cached forever if file
attributes was changed and/or file was extended.
diff --git a/src/core/ngx_open_file_cache.c b/src/core/ngx_open_file_cache.c
--- a/src/core/ngx_open_file_cache.c
+++ b/src/core/ngx_open_file_cache.c
@@ -284,13 +284,11 @@ ngx_open_cached_file(ngx_open_file_cache
if (of->uniq == file->uniq) {
- file->count++;
-
if (file->event) {
file->use_event = 1;
}
- goto renew;
+ goto update;
}
/* file was changed */
@@ -394,8 +392,6 @@ update:
}
}
-renew:
-
file->created = now;
found:
Подробная информация о списке рассылки nginx-ru