У меня Puma работает как восходящий сервер приложений, а Riak - как мой фоновый кластер БД. Когда я отправляю запрос, который сокращает фрагмент данных примерно для 25 тысяч пользователей и возвращает его из Riak в приложение, я получаю сообщение об ошибке в журнале Nginx:
Истекло время ожидания восходящего потока (110: Истекло время ожидания соединения) при чтении заголовка ответа из восходящего потока
Если я запрашиваю свой апстрим напрямую, без прокси-сервера nginx, с тем же запросом я получаю необходимые данные.
Тайм-аут Nginx наступает после установки прокси.
**nginx.conf**
http {
keepalive_timeout 10m;
proxy_connect_timeout 600s;
proxy_send_timeout 600s;
proxy_read_timeout 600s;
fastcgi_send_timeout 600s;
fastcgi_read_timeout 600s;
include /etc/nginx/sites-enabled/*.conf;
}
**virtual host conf**
upstream ss_api {
server 127.0.0.1:3000 max_fails=0 fail_timeout=600;
}
server {
listen 81;
server_name xxxxx.com; # change to match your URL
location / {
# match the name of upstream directive which is defined above
proxy_pass http://ss_api;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_cache cloud;
proxy_cache_valid 200 302 60m;
proxy_cache_valid 404 1m;
proxy_cache_bypass $http_authorization;
proxy_cache_bypass http://ss_api/account/;
add_header X-Cache-Status $upstream_cache_status;
}
}
В Nginx есть несколько директив тайм-аута. Не знаю, упускаю ли я что-то важное. Любая помощь будет высоко ценится....