Il semble que nginx 0.8.35 puisse prendre en charge le codage de transfert par blocs :
Modifications avec nginx 0.8.35 01 avr 2010
*) Change: now the charset filter runs before the SSI filter. *) Feature: the "chunked_transfer_encoding" directive.
C'est génial, car j'essaye d'obtenir des modifications push git via un proxy inverse nginx vers un processus git-http-backend. Git HTTP tire parti du codage de transfert par blocs pour des raisons d'efficacité côté client .
Cependant, je ne peux pas le faire fonctionner. J'utilise nginx 0.8.44 sur Debian Lenny avec l'invocation de configuration suivante:
./configure \
--sbin-path=/usr/sbin \
--conf-path=/etc/nginx/nginx.conf \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--user=www-data \
--group=www-data \
--pid-path=/var/run/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--with-http_ssl_module \
--with-http_gzip_static_module \
--with-http_realip_module
Et le fichier de conf suivant:
server {
server_name example.com;
location / {
proxy_pass http://192.168.0.10;
include /etc/nginx/proxy.conf;
chunked_transfer_encoding on;
}
}
Et mon proxy.conf
look ressemble à ceci:
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 100M;
client_body_buffer_size 128k;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
(À l'origine, j'ai posté cette question sur Stack Overflow mais on m'a dit qu'elle était plus appropriée à la défaillance du serveur)