error_page and Content-Length: 0
ash2k -
ash2kk на gmail.com
Пн Дек 14 14:13:03 MSK 2009
Здравствуйте! Помогите пожалуйста разобраться с проблемой.
FreeBSD 7.2-STABLE amd62, nginx/0.7.64
-------------------------------------------
$ telnet 127.0.0.1 5190
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
GET /a HTTP/1.0
HTTP/1.1 200 OK
Server: nginx
Date: Mon, 14 Dec 2009 10:32:34 GMT
Content-Type: image/png
Connection: close
-------------------------------------------
$ telnet 127.0.0.1 5190
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
GET /b HTTP/1.0
HTTP/1.1 404 Not Found
Server: nginx
Date: Mon, 14 Dec 2009 10:38:20 GMT
Content-Type: image/png
Connection: close
-------------------------------------------
$ telnet 127.0.0.1 5190
Trying 127.0.0.1...
Connected to localhost.
Escape character is '^]'.
GET /c HTTP/1.0
HTTP/1.1 404 Not Found
Server: nginx
Date: Mon, 14 Dec 2009 10:40:10 GMT
Content-Type: image/png
Content-Length: 0
Connection: close
-------------------------------------------
Непонятно откуда берется заголовок "Content-Length: 0" - в PHP скрипте
его нет да и если добавить fastcgi_hide_header Content-Length то он
остается.
Во всех трех случаях отдается нормальная PNGшка, но в последнем
браузер ее не отображает из-за "Content-Length: 0" видимо.
Логика работы последнего (/c) location:
1. пытаемся считать из mogilefs несуществующей файл
2. на 404 переходим в @boxMogilefs
3. PHP скрипт возвращает 404
4. на 404 переходим в @boxUniversal404
5. PHP возвращает PNGшку
Конфиг:
server {
listen 127.0.0.1:5190
default;
access_log off;
proxy_intercept_errors on;
fastcgi_intercept_errors on;
recursive_error_pages on;
error_page 404
/img/imagenotfound.png;
location /img/ {
root /home/cropbox/www/linkme;
}
location = /a {
set $box_source
/home/app_cropbox/img/imagenotfound.png;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME
/home/app_cropbox/cropbox/boxUniversal.php;
fastcgi_param QUERY_STRING
source=$box_source&newMaxWidth=100&newMaxHeight=100&cutHeight=0;
fastcgi_pass cropbox;
}
location = /b {
error_page 404 @boxUniversal404;
set $box_filename
donotexist.png;
set $box_newMaxWidth 100;
set $box_newMaxHeight 100;
set $box_cutHeight 0;
return 404;
}
location = /c {
set $box_filename dontexist.png;
set $box_newMaxWidth 100;
set $box_newMaxHeight 100;
set $box_cutHeight 0;
error_page 404 = @boxMogilefs;
mogilefs_domain <domain>;
mogilefs_methods GET;
mogilefs_tracker <ip>:<port>;
mogilefs_pass $box_filename {
proxy_pass $mogilefs_path;
proxy_hide_header Content-Type;
proxy_buffering off;
}
}
location @boxUniversal404 {
set $box_source
/home/app_cropbox/img/imagenotfound.png;
error_page 404 /img/imagenotfound.png;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME
/home/app_cropbox/cropbox/boxUniversal.php;
fastcgi_param QUERY_STRING
source=$box_source&newMaxWidth=$box_newMaxWidth&newMaxHeight=$box_newMaxHeight&cutHeight=$box_cutHeight;
fastcgi_pass cropbox;
}
location @boxMogilefs {
error_page 404 @boxUniversal404;
include fastcgi_params;
# fastcgi_hide_header Content-Length;
fastcgi_param SCRIPT_FILENAME
/home/app_cropbox/cropbox/boxMogilefs.php;
fastcgi_param QUERY_STRING
filename=$box_filename&newMaxWidth=$box_newMaxWidth&newMaxHeight=$box_newMaxHeight&cutHeight=$box_cutHeight;
fastcgi_pass cropbox;
}
}
Подробная информация о списке рассылки nginx-ru