Potrzebuję nginx proxy użyć pamięci podręcznej, jeśli serwer zaplecza nie działa:
to moja konfiguracja. ale wygląda na to, że nginx używa pamięci podręcznej bez sprawdzania serwera zaplecza.
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;
}
}
}
Pytanie brzmi, jak mogę ominąć pamięć podręczną proxy, jeśli serwer zaplecza jest uruchomiony? A kiedy serwer zaplecza jest włączony, mój serwer proxy w ogóle nie używa pamięci podręcznej.
Odpowiedzi:
Wydaje się duplikatem tego:
/programming/16756271/how-to-configure-nginx-to-serve-cached-content-only-when-backend-is-down-5xx-re
W skrócie, użyj proxy_cache_use_stale
Jako aktualizację przetestowałem to i działa dobrze. Zrobiłem test na mojej stacji roboczej, gdzie mam (dla kompletności):
Fedora 23 nginx 1.8.1 skonfigurowana jako terminator ssl + pamięć podręczna + zwrotny serwer proxy Apache 2.4.18 skonfigurowany do nasłuchiwania na porcie 80
Z apache działającym jako upstream, obsługującym tylko plik statyczny, zrobiłem ten test:
Użyłem konfiguracji nginx (tylko ciekawe części):
nginx.conf:
/etc/nginx/conf.d/local.conf:
źródło
Użyj proxy_intercept_errors i proxy 500 do serwera z włączonym buforowaniem.
źródło