it-swarm.com.ru

Как предотвратить тайм-аут шлюза с FastCGI на Nginx

Я использую Django, FastCGI и Nginx. Я создаю API-интерфейс, который позволяет отправлять некоторые данные через XML, которые я буду обрабатывать, а затем возвращать некоторые коды состояния для каждого отправленного узла.

Проблема в том, что Nginx выдаст тайм-аут шлюза 504, если я потрачу слишком много времени на обработку XML - думаю, больше 60 секунд.

Поэтому я хотел бы настроить Nginx так, чтобы при возникновении каких-либо запросов, соответствующих местоположению/API, время ожидания не превышало 120 секунд. Какая настройка будет выполнять это.

То, что я до сих пор это:

    # Handles all api calls
    location ^~ /api/ {
        proxy_read_timeout 120;
        proxy_connect_timeout 120;
        fastcgi_pass 127.0.0.1:8080;
    }

Правка: что у меня не работает :)

196
sheats

Тайм-ауты прокси хорошо, для прокси, а не для FastCGI ...

Директивы, которые влияют на таймауты FastCGI: client_header_timeout, client_body_timeout и send_timeout.

Редактировать : Учитывая то, что найдено в вики nginx, директива send_timeout отвечает за установку общего времени ожидания ответа (что немного вводит в заблуждение) ). Для FastCGI есть fastcgi_read_timeout, который влияет на время ожидания ответа процесса fastcgi .

НТН.

241
zgoda

Для тех, кто использует nginx с Unicorn и Rails, скорее всего таймаут указан в вашем файле Unicorn.rb

положить большой таймаут в Unicorn.rb

timeout 500

если вы все еще сталкиваетесь с проблемами, попробуйте указывать fail_timeout = 0 в апстриме в nginx и посмотрите, исправит ли это вашу проблему. Это для целей отладки и может быть опасно в производственной среде.

upstream foo_server {
        server 127.0.0.1:3000 fail_timeout=0;
}
23
Abdo

В разделе http nginx (/etc/nginx/nginx.conf) добавьте или измените:

keepalive_timeout 300s

В разделе server nginx (/etc/nginx/sites-available/your-config-file.com) добавьте эти строки:

client_max_body_size 50M;
fastcgi_buffers 8 1600k;
fastcgi_buffer_size 3200k;
fastcgi_connect_timeout 300s;
fastcgi_send_timeout 300s;
fastcgi_read_timeout 300s;

В файле php для случая 127.0.0.1:9000 (/etc/php/7.X/fpm/pool.d/www.conf) изменить:

request_terminate_timeout = 300

Я надеюсь помочь вам.

1
Jose Carlos Ramos Carmenates

Если вы используете Unicorn.

Посмотрите на top на вашем сервере. Вероятно, сейчас Unicorn использует 100% процессорного времени. Есть несколько причин этой проблемы.

  • Вы должны проверить свои HTTP-запросы, некоторые из них могут быть очень сложными.

  • Проверьте версию Unicorn. Может быть, вы недавно обновили его, и что-то сломалось.

1
Pavel Kalashnikov