Назад | Перейти на главную страницу

nginx использует кеш прокси, если бэкэнд не работает

Мне нужно, чтобы прокси-сервер nginx использовал кеш, если бэкэнд-сервер не работает:

это моя конфигурация. но, похоже, nginx использует кеш без проверки внутреннего сервера.

http {

  # ...

  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  proxy_cache_path /tmp/nginx levels=1:2 keys_zone=tmpzone:10m inactive=60m;
  proxy_cache_key "$scheme$request_method$host$request_uri";


  server {
    server_name _;

    location / {
      proxy_connect_timeout 5s;
      proxy_read_timeout 5s;
      proxy_cache tmpzone;
      proxy_cache_valid      200 304 1d;
      proxy_cache_use_stale  error timeout invalid_header updating http_500 http_502 http_503 http_504;
      proxy_set_header X-Real-IP  $remote_addr;
      proxy_set_header X-Forwarded-For $remote_addr;
      proxy_set_header Host 'www.example.com';
      proxy_pass http://www.example.com;
    }
  }
}

Вопрос в том, как я могу обойти кеш прокси, если бэкэнд-сервер работает? И когда бэкэнд-сервер работает, мой прокси-сервер вообще не использует кеш.

Кажется, это дубликат:

https://stackoverflow.com/questions/16756271/how-to-configure-nginx-to-serve-cached-content-only-when-backend-is-down-5xx-re

Короче говоря, используйте proxy_cache_use_stale

В качестве обновления я протестировал это, и он отлично работает. Я провел тест на своей рабочей станции, где у меня (для полноты):

Fedora 23 nginx 1.8.1 настроен как терминатор ssl + кеш + обратный прокси Apache 2.4.18 настроен для прослушивания на порту 80

Когда apache действует как восходящий поток, обслуживая только статический файл, я провел этот тест:

  1. Apache вверх, nginx вверх, указывая браузеру на URL-адрес обратного проксирования, обслуживаемый nginx, я вижу прокси-контент из Apache. На этом этапе nginx хранит это в кеше.
  2. Остановлен apache
  3. при подключении к nginx я вижу, что кешированный файл ранее обслуживался Apache.

Я использовал конфигурацию nginx (только интересные части):

nginx.conf:

http {
[...]
location
    proxy_cache_path        /var/lib/nginx/tmp/proxy/ levels=1:2 keys_zone=STATIC:10m inactive=24h max_size=1g;
    include /etc/nginx/conf.d/*.conf;
}

/etc/nginx/conf.d/local.conf:

upstream localhost {
    server 127.0.0.1:80;
[...]
}


server {
    listen       127.0.0.1:443 ssl;

[...]

    location /be/ {
        proxy_pass              http://localhost;
        proxy_cache             STATIC;
        proxy_cache_valid       200 1d;
        proxy_cache_use_stale   error;
}

Используйте proxy_intercept_errors и прокси 500 для сервера, на котором включено кеширование.