Nginx-ru mailing list archive (nginx-ru@sysoev.ru)
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Разъяснения по работе proxy_next_upstream
- To: nginx-ru@xxxxxxxxx
- Subject: Разъяснения по работе proxy_next_upstream
- From: Alexander Zhuravlev <scif-1986@xxxxxxxxx>
- Date: Wed, 23 May 2012 19:03:10 +1100
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yandex.ru; s=mail; t=1337760192; bh=Qq2mYw+fYQyqp24eXki3ZvnWq9gBPETeHzf72m+u4is=; h=Message-ID:Date:From:MIME-Version:To:Subject:Content-Type: Content-Transfer-Encoding; b=MAeeILdMce4Do/trMB5A2JUJSoDVdJvkw/oP6gJ7ayImLHn5BWPZBs1DA+lFz2R5/ pawuNDWIgT7rgfwNJaODBptzMY00elMHwP2SezgKOS8HDLb108fY7ygrAgQPf4zBlB +Ez+L974Cu1Vm7oUrTsYP9muW3xkro/ps5hSPyz4=
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=yandex.ru; s=mail; t=1337760192; bh=Qq2mYw+fYQyqp24eXki3ZvnWq9gBPETeHzf72m+u4is=; h=Message-ID:Date:From:User-Agent:MIME-Version:To:Subject: Content-Type:Content-Transfer-Encoding; b=UexjPcvRVA3489DlfYlxS9RI+cQJgKhFhxqNuuXImSHi90UqOrIzKxPEDpZg5N/sg 9Lg7vnrTRsjZqwyDcP+TKQSYahBNJIFy2AmmRU0N0Ng5GZF/bl1xm7n+e1gw3KABe+ KVjP7sKC/83bhoRsMzDvzz0p3X9WEKJT7p+70Y1I=
Добрый день всем.
Не совсем уверен, что дело именно в proxy_next_upstream, поэтому
поправьте если не прав.
Проблема: есть веб-сервис (java playframework), он обрабатывает внешние
запросы и хочется умудриться рестартовать сам демон, не потеряв
пользовательские запросы. Разъясню: сам демон рестартует порядка 2
секунд. За это время на nginx поступает порядка 20-50 запросов. Хочется
сложить их в некий буфер и дождаться подъёма сервера. Да, понимаю, что
запросы будут обрабатываться не 0.1сек, а 2.1-2.5сек, но главно чтобы
они были обработаны, а не получили 502-ую. Насколько я понимаю
реализовать это можно только установкой самого себя в резервные сервера
и установкой таймаута за который демон должен рестартовать.
Накропал конфиг:
upstream local_upstream {
server 127.0.0.1:9012 fail_timeout=12s max_fails=1;
server localhost:9012 backup;
}
server {
proxy_connect_timeout 5s;
listen 80;
server_name localhost;
error_log /var/log/nginx/exporter.error.log;
proxy_next_upstream timeout;
root /opt/app/views;
location / {
proxy_pass http://local_upstream;
proxy_set_header Host $http_host;
}
Считал, что согласно proxy_next_upstream сервер будет считаться мёртвым
только по истечении времени, но что-то нифига не так :(
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru
|