обратный прокси-сервер nginx отключает кеш - PullRequest
0 голосов
/ 10 января 2019

Я использую nginx в качестве обратного прокси для подключения API. Проблема в том, когда я отправляю запрос после добавления или удаления чего-либо. Nginx пришлите мне старое значение JSON. Я пытался отключить кэш, но он не работает.

мой конфиг nginx:

location  / {

  sendfile off;
  add_header Last-Modified $date_gmt;
  add_header Cache-Control 'no-store, no-cache, must-revalidate, proxy-revalidate, max-age=0';
  if_modified_since off;
  expires off;
  etag off;
  proxy_no_cache 1;
  proxy_cache_bypass 1;

  proxy_pass http://127.0.0.1:5000;
  proxy_set_header Host $http_host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-Proto $scheme;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_set_header HTTPS   $https;
}

Я попробовал запрос без nginx и все хорошо работает в консоли

спасибо!

1 Ответ

0 голосов
/ 22 мая 2019

Согласно документации proxy_cache необходимо заменить

proxy_no_cache 1;
proxy_cache_bypass 1;

proxy_no_cache и proxy_cache_bypass определяет условия, при которых ответ не будет сохранен в кэш.

Затем, чтобы отключить кеш, вы можете заменить эти два условия на

proxy_cache off;

Здесь приведен полный пример, который вы можете использовать для настройки прокси-сервера для сервера API без сохранения состояния

location /myapi {

        # Proxy 
        proxy_set_header                X-Localhost true;
        proxy_set_header                X-Real-IP $remote_addr;
        proxy_set_header                X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass                      http://localhost:8080/myapi;

        proxy_redirect                  off;
        proxy_buffers                   32 16k;
        proxy_busy_buffers_size         64k;
        proxy_cache                     off;


        # Headers for client browser NOCACHE + CORS origin filter 
        add_header 'Cache-Control' 'no-store, no-cache, must-revalidate, proxy-revalidate, max-age=0';
        expires off;
        add_header    'Access-Control-Allow-Methods' 'GET, POST, OPTIONS' always;
        add_header    'Access-Control-Allow-Headers' 'Origin, X-Requested-With, Content-Type, Accept' always;

        allow all;
    }
...